QT學習筆記4(動畫)
Qt自帶的動畫框架用來做簡單的控制元件動畫效果是比較簡單易用的,像是對控制元件的位移、縮放、不透明度這些來做動畫效果。
動畫框架結構
動畫框架結構
動畫框架由基類QAbstractAnimation以及它的兩個子類QVariantAnimation、QAnimationGroup組成。基礎動畫由QVariantAnimation的子類QPropertyAnimation來設定,再通過將多個QPropertyAnimation和QPauseAnimation組合成為動畫組(QParallelAnimationGroup、QSequentialAnimationGroup),完成一個連續的動畫。
QPropertyAnimation
QPropertyAnimation類能夠修改Qt的屬性值,如pos、geometry等屬性。設定好動畫的初值和末值,以及持續的時間後,一個屬性動畫就基本完成了。
縮放
通過修改控制元件的geometry屬性可以實現縮放效果,也可以實現位移的動畫,該屬性的前兩個值確定了控制元件左上角的位置,後兩個值確定了控制元件的大小。
//scale
QPropertyAnimation *pScaleAnimation1 = new QPropertyAnimation(ui->scaleButton, "geometry");
pScaleAnimation1->setDuration(1000);
pScaleAnimation1->setStartValue(QRect(190, 230, 0, 0));
pScaleAnimation1->setEndValue(QRect(120, 160, 140, 140));
位移
如果只是需要位移動畫的話,修改控制元件的pos屬性即可。pos屬性就是控制元件的左上角所在的位置。
//pos
QPropertyAnimation *pPosAnimation1 = new QPropertyAnimation(ui->posButton, "pos");
pPosAnimation1->setDuration(1000);
pPosAnimation1->setStartValue(QPoint(360, 160));
pPosAnimation1->setEndValue(QPoint(360, 350));
pPosAnimation1->setEasingCurve(QEasingCurve::InOutQuad);
不透明度
Qt的控制元件沒有單獨的透明度屬性,要修改控制元件的透明度可以通過QGraphicsOpacityEffect類來實現。
//opacity
QGraphicsOpacityEffect *pButtonOpacity = new QGraphicsOpacityEffect(this);
pButtonOpacity->setOpacity(1);
ui->opasityButton->setGraphicsEffect(pButtonOpacity);
QPropertyAnimation *pOpacityAnimation1 = new QPropertyAnimation(pButtonOpacity, "opacity");
pOpacityAnimation1->setDuration(1000);
pOpacityAnimation1->setStartValue(1);
pOpacityAnimation1->setEndValue(0);
動畫曲線
動畫還可以設定時間的插值曲線,預設是linear,即線性運動,通過設定QEasingCurve即可。Qt提供了40種已經定義好的曲線(如果有需要也可以自定義曲線):
動畫曲線
pScaleAnimation1->setEasingCurve(QEasingCurve::InOutQuad);
QSequentialAnimationGroup
序列動畫分組
通過將QPropertyAnimation或者QPauseAnimation加入,構成一個按加入順序依次播放的動畫組,動畫組的總時長是各個加入動畫的總和。
QSequentialAnimationGroup *pPosGroup = new QSequentialAnimationGroup(this);
pPosGroup->addPause(500);
pPosGroup->addAnimation(pPosAnimation1);
往返運動
Qt的動畫可以設定迴圈次數,預設的迴圈是從頭再播放一遍,往返運動可以在一個序列動畫組中加入初值末值相反的一組動畫來實現。
QParallelAnimationGroup
並行動畫組
加入並行動畫組的動畫會同時播放,動畫組的總時長是最長的動畫所需的時間。
m_group = new QParallelAnimationGroup(this);
m_group->addAnimation(pScaleGroup);
m_group->addAnimation(pPosGroup);
m_group->addAnimation(pOpacityGroup);
延時播放
在序列動畫組的開始先加入一個QPauseAnimation,再將Pause不同的序列動畫組加入並行動畫組就可以實現延時效果了。
動畫方向
預設動畫是從開始到結束這個方向播放的, 可以設定為從結束到開始播放。
m_group->setDirection(QAbstractAnimation::Backward);
綜合例子:
縮放動畫:
setMinimumSize(600,500);
QLabel * label = new QLabel(this);
label->setGeometry(130,130,140,140);
label->setStyleSheet("background-color:red;");
QPropertyAnimation *pScaleAnimation = new QPropertyAnimation(label, "geometry");
pScaleAnimation->setDuration(500);
pScaleAnimation->setStartValue(QRect(200,200, 0, 0));
pScaleAnimation->setEndValue(QRect(130, 130, 140, 140));
QSequentialAnimationGroup *sequentialAnimationGroup = new QSequentialAnimationGroup(this);
sequentialAnimationGroup->addPause(500);
sequentialAnimationGroup->addAnimation(pScaleAnimation);
QParallelAnimationGroup * parallelAnimationGroup = new QParallelAnimationGroup(this);
parallelAnimationGroup->addAnimation(sequentialAnimationGroup);
parallelAnimationGroup->setDirection(QAbstractAnimation::Forward);
parallelAnimationGroup->setLoopCount(-1);
parallelAnimationGroup->start();
opacity動畫:
QLabel * label = new QLabel(this);
label->setGeometry(130,130,140,140);
label->setStyleSheet("background-color:red;");
//opacity
QGraphicsOpacityEffect * graphicsOpacityEffect = new QGraphicsOpacityEffect(this);
graphicsOpacityEffect->setOpacity(1);
label->setGraphicsEffect(graphicsOpacityEffect);
QPropertyAnimation *pScaleAnimation = new QPropertyAnimation(graphicsOpacityEffect, "opacity");
pScaleAnimation->setDuration(500);
pScaleAnimation->setStartValue(1);
pScaleAnimation->setEndValue(0);
QSequentialAnimationGroup *sequentialAnimationGroup = new QSequentialAnimationGroup(this);
sequentialAnimationGroup->addPause(500);
sequentialAnimationGroup->addAnimation(pScaleAnimation);
QParallelAnimationGroup * parallelAnimationGroup = new QParallelAnimationGroup(this);
parallelAnimationGroup->addAnimation(sequentialAnimationGroup);
parallelAnimationGroup->setDirection(QAbstractAnimation::Forward);
parallelAnimationGroup->setLoopCount(-1);
parallelAnimationGroup->start();
位置動畫:
QLabel * label = new QLabel(this);
label->setGeometry(130,130,140,140);
label->setStyleSheet("background-color:red;");
//pos
QPropertyAnimation *pScaleAnimation = new QPropertyAnimation(label, "pos");
pScaleAnimation->setDuration(500);
pScaleAnimation->setStartValue(QPoint(130,130));
pScaleAnimation->setEndValue(QPoint(200,200));
QSequentialAnimationGroup *sequentialAnimationGroup = new QSequentialAnimationGroup(this);
sequentialAnimationGroup->addPause(500);
sequentialAnimationGroup->addAnimation(pScaleAnimation);
QParallelAnimationGroup * parallelAnimationGroup = new QParallelAnimationGroup(this);
parallelAnimationGroup->addAnimation(sequentialAnimationGroup);
parallelAnimationGroup->setDirection(QAbstractAnimation::Forward);
parallelAnimationGroup->setLoopCount(-1);
parallelAnimationGroup->start();
相關文章
- iOS學習筆記-動畫篇1iOS筆記動畫
- Qt學習筆記(五)QString 字串QT筆記字串
- swift學習筆記《4》Swift筆記
- Rails 4 學習筆記AI筆記
- CCNA學習筆記4筆記
- vue學習筆記4Vue筆記
- Java學習筆記4Java筆記
- python學習筆記4Python筆記
- Webpack4學習筆記Web筆記
- p4 學習筆記筆記
- Android學習筆記(4)Android筆記
- 【Go學習筆記4】切片Go筆記
- PL/SQL學習筆記-4SQL筆記
- ruby字串學習筆記4字串筆記
- ReactNative學習筆記四之動畫篇React筆記動畫
- G01學習筆記-4筆記
- SpringBoot學習筆記(4)Spring Boot筆記
- SpringCloud學習筆記(4)——ZuulSpringGCCloud筆記Zuul
- angular學習筆記(十四)-$watch(4)Angular筆記
- Qt Creator 原始碼學習筆記01,初識QTCQT原始碼筆記
- 強化學習-學習筆記4 | Actor-Critic強化學習筆記
- OpenCV學習筆記(4)——mixChannels函式OpenCV筆記函式
- Flutter學習筆記(4)--Dart函式Flutter筆記Dart函式
- Python-BeautifulSoup4 學習筆記Python筆記
- VisionPro學習筆記(4)——PatInspect筆記
- Linux學習筆記 Day 4~5Linux筆記
- 兒童教育講座 - 學習筆記 4筆記
- docx4j學習筆記(1)筆記
- angular學習筆記(三十)-指令(4)-transcludeAngular筆記
- oracle 學習筆記---效能優化(4)Oracle筆記優化
- WORD SMART單詞學習筆記4筆記
- python爬蟲—學習筆記-4Python爬蟲筆記
- web基礎學習筆記(二十)之jquery動畫操作Web筆記jQuery動畫
- 『Material Design入門學習筆記』動畫(含demo)Material Design筆記動畫
- Activity之間的動畫切換學習筆記(一)動畫筆記
- Qt4.8.5 + VS2010 學習筆記QT筆記
- C++學習筆記(七) - Qt 在控制檯輸出C++筆記QT
- XML初學進階學習筆記(4)(轉)XML筆記