查看完整版本: [-- zhengtianzuo系列-Qt动画控制效果 --]

QTCN开发网 -> Qt代码秀 -> zhengtianzuo系列-Qt动画控制效果 [打印本页] 登录 -> 注册 -> 回复主题 -> 发表主题

zhengtianzuo 2017-09-30 16:45

zhengtianzuo系列-Qt动画控制效果

    首先需要创建一个状态机对被控制对象的状态, 动画效果, 信号触发等进行统一管理.

    //创建状态机
    QStateMachine *pStateMachine = new QStateMachine(this);


    然后根据动画需求设置状态, 比如希望一个按钮从左边移动到右边, 并且移动过程中放大到2倍.

    //设置起始状态
    QState *pStartState = new QState(pStateMachine);

    //绑定属性
    pStartState->assignProperty(pButton, "geometry",
            QRect(10,(this->height()-pButton->height())/2,pButton->width(),pButton->height()));

    //设置为起始状态
    pStateMachine->setInitialState(pStartState);

    //设置结束状态
    QState *pEndState = new QState(pStateMachine);

    //绑定属性
    pEndState->assignProperty(pButton, "geometry",
            QRect(this->width()-pButton->width()*2-10,
            (this->height()-pButton->height()*2)/2,
            pButton->width()*2,pButton->height()*2));

    绑定状态属性的时候描述好属性内容, 比如坐标和宽高.
    然后设置动画效果

    //设置动画效果
    QPropertyAnimation *pPropertyAnimation = new QPropertyAnimation(pButton, "geometry");
    pPropertyAnimation->setDuration(2000);
    pPropertyAnimation->setEasingCurve(QEasingCurve::OutBounce);

    接下来绑定动画信号槽

    //绑定动画信号槽
    QSignalTransition *pTransitionStart2End = pStartState->addTransition(pButton, SIGNAL(clicked()), pEndState);
    pTransitionStart2End->addAnimation(pPropertyAnimation);

    QSignalTransition *pTransitionEnd2Start = pEndState->addTransition(pButton, SIGNAL(clicked()), pStartState);
    pTransitionEnd2Start->addAnimation(pPropertyAnimation);

    最后就可以启动状态机了

    //开启状态机
    pStateMachine->start();



需要完整代码请访问 QtWidgetsExamples

洗洗睡咯 2017-10-05 19:24
不错不错

看山不是山 2017-10-10 23:23
   潜水员出来 顶贴 。内容不错

big_mouse 2020-04-22 09:11


查看完整版本: [-- zhengtianzuo系列-Qt动画控制效果 --] [-- top --]



Powered by phpwind v8.7 Code ©2003-2011 phpwind
Gzip disabled