Qt-4.6新增了Animation Framework(动画框架),让我们可以方便的写一些生动的程序。

不必像曾经的版本号一样,全部的控件都枯燥的呆在伟大光荣的QLayout里,或许它们可以唱个歌,跳个舞。

    所谓动画就是在一个时间段内的不同一时候间点有不同的状态。仅仅要定义好这样状态。实现动画就是水到渠成的事情。当然做这件事情,最好用的就是状态机,没错Qt-4.6.0提供了QStateMachine类,只是今天我要讲的三字决要简单一些。

第一决:QPropertyAnimation



QPropertyAnimation用于和QObject中的属性properties进行通信,比方QWidget的大小。坐标等。来看代码

引用
QPropertyAnimation *animation = new QPropertyAnimation(myWidget, “geometry”);

animation->setDuration(10000);

animation->setStartValue(QRect(0, 0, 100, 30));

animation->setEndValue(QRect(250, 250, 100, 30));

animation->start();

第 一行创建的QPropertyAnimation对象关联了myWidget这个窗口的几何属性。后面的几句分别设置了这个动画的时长。起始坐标和结束坐 标。剩下的事情就交改QProperAnimation去做即可了。

然后调用start()启动它。没错。五行代码就完毕了一个完毕了一个自己主动从一个坐标 点移动到还有一个坐标点的窗口。以下我给出一个能够执行的代码,是一仅仅小鸟从下角移到中间的一个小动画,当然你得自己准备这个同名的图片:)

  1. #include <QApplication>

    #include <QLabel>

    #include <QPixmap>

    #include <QPropertyAnimation>



    int main(int argc,char *argv[]){

        QApplication app(argc,argv);

        QWidget *w=new QWidget();

        w->resize(300,400);

        QPixmap birdimg=QPixmap(”twitter-bird.png”).scaled(40,40);

        QLabel *bird_1=new QLabel(w);

        bird_1->setPixmap(birdimg);

        QPropertyAnimation *anim1=new QPropertyAnimation(bird_1, “pos”);

        anim1->setDuration(2000);

        anim1->setStartValue(QPoint(0, 360));

        anim1->setEndValue(QPoint(110, 180));

        anim1->start();

        bird_1->move(-40,-40);

        w->show();

        return app.exec();

    }

上面的样例使用了label的位置属性pos。当然你能够在自己的类里添加其他property的。比方让颜色在变。



第二决:setEasingCurve



上 面那个样例中小鸟的移动是线性的,未免太单调了点。QPropertyAnimation中的void setEasingCurve (const QEasingCurve & easing)函数正是用于实现不同的曲率变化的,QEasingCurve可用的參数列表(包含函数曲线图)可在文档中查到 。将上面动画相关的代码部分改成

引用
QPropertyAnimation *anim1=new QPropertyAnimation(bird_1, “pos”);

anim1->setDuration(2000);

anim1->setStartValue(QPoint(0, 360));

anim1->setEndValue(QPoint(110, 180));

anim1->setEasingCurve(QEasingCurve::OutBounce);

anim1->start();

注意。新增的第四句。

而且试试其他曲线參数。然后执行,看到的动态效果是不是不一样了。假设你对列表里已经有的曲线都不惬意。你还能够继承QEasingCurve,实现你须要的效果。

第三决:QAnimationGroup



前 面的样例是仅仅有一个动画在执行,假设想多个动画一起执行的话,那就要用到动画组QAnimationGroup了。动画组分为两种分别为串行和并行,相应 于QAnimationGroup的两个子类QSequentialAnimationGroup和QParallelAnimationGroup。

其 使用方法非常easy

引用
QSequentialAnimationGroup group;

//QParallelAnimationGroup group;

group.addAnimation(anim1);

group.addAnimation(anim2);

group.start();

上 面的代码,假设是串行的话,那么动画anim1执行之后,才会执行anim2。

假设是并行的话,两个动画是同一时候执行的。假设加了动画组,那么单个 anim1->start()就不是必需再单独调用了,由动画组来管理。 以下是一个可执行的代码,两仅仅小鸟分别从窗口左上角和右下角移动到中间。

  1. #include <QApplication>

    #include <QWidget>

    #include <QLabel>

    #include <QPixmap>

    #include <QPropertyAnimation>

    #include <QSequentialAnimationGroup>

    #include <QParallelAnimationGroup>



    int main(int argc,char *argv[]){

        QApplication app(argc,argv);

        QWidget *w=new QWidget();

        w->resize(300,400);

        QPixmap birdimg=QPixmap(”twitter-bird.png”).scaled(40,40);

        QLabel *bird_1=new QLabel(w);

        bird_1->setPixmap(birdimg);

        QPropertyAnimation *anim1=new QPropertyAnimation(bird_1, “pos”);

        anim1->setDuration(2000);

        anim1->setStartValue(QPoint(0, 360));

        anim1->setEndValue(QPoint(110, 180));

        //anim1->setEasingCurve(QEasingCurve::OutBounce);

        anim1->start();

        QLabel *bird_2=new QLabel(w);

        bird_2->setPixmap(birdimg);

        QPropertyAnimation *anim2=new QPropertyAnimation(bird_2, “pos”);

        anim2->setDuration(2000);

        anim2->setStartValue(QPoint(0, 0));

        anim2->setEndValue(QPoint(150, 180));

        anim2->setEasingCurve(QEasingCurve::OutBounce);

        QSequentialAnimationGroup group;

        //QParallelAnimationGroup group;

        group.addAnimation(anim1);

        group.addAnimation(anim2);

        group.start();

        bird_1->move(-40,-40);

        bird_2->move(-40,-40);

        w->show();

        return app.exec();

    }

转自http://blog.163.com/benben_long/blog/static/1994582432012312105857888/

qt动画入门的更多相关文章

  1. 转 iOS Core Animation 动画 入门学习(一)基础

    iOS Core Animation 动画 入门学习(一)基础 reference:https://developer.apple.com/library/ios/documentation/Coco ...

  2. Qt动画效果的实现,QPropertyAnimation

    Qt动画架构中的主要类如下图所示: 动画框架由基类QAbstractAnimation和它的两个儿子QVariantAnimation和QAnimationGroup组成.QAbstractAnima ...

  3. Qt动画与Qt坐标小记

    Qt动画 转载自: <http://jingyan.baidu.com/article/154b46315757b628ca8f4116.html> 和  <http://blog. ...

  4. Qt快速入门系列教程目录

    Qt快速入门系列教程目录

  5. QT动画介绍(有例子可以下载)

    所谓动画就是在一个时间段内的不同时间点有不同的状态,只要定义好这样状态,实现动画就是水到渠成的事情.当然做这件事情,最好用的就是状态机,点击这里查看Qt使用状态机实现动画效果实例. 不过,实现动画也有 ...

  6. Qt快速入门学习笔记(基础篇)

    本文基于Qter开源社区论坛版主yafeilinux编写的<Qt快速入门系列教程目录>,网址:http://bbs.qter.org/forum.php?mod=viewthread&am ...

  7. Qt动画框架The Animation Framework

    动画框架是Kinetic(运动)项目的一部分,它的目标是提供一中简单的方法创建动画的和流畅的GUI.借助Qt动画属性,可以提供非常自由的动画窗体组件和其他对象(QObjects).动画框架也能被用于图 ...

  8. 第15.10节 PyQt(Python+Qt)入门学习:Qt Designer可视化设计界面组件与QWidget类相关的组件属性详解

    PyQt学习有阵子了,对章节的骨架基本考虑好了,准备本节就写组件的属性的,结果一是日常工作繁忙,经常晚上还要加班,二是Qt的组件属性很多,只能逐一学习.研究和整理,花的时间有点长,不过终于将可视化设计 ...

  9. QT从入门到入土(二)——对象模型(对象树)和窗口坐标体系

    摘要 我们使用的标准 C++,其设计的对象模型虽然已经提供了非常高效的 RTTI 支持,但是在某些方面还是不够灵活.比如在 GUI 编程方面,既需要高效的运行效率也需要强大的灵活性,诸如删除某窗口时可 ...

随机推荐

  1. int long long 的范围

    unsigned   int     0-4294967295   (10位数,4e9) int                        -2147483648-2147483647  (10位 ...

  2. idea导入jdk源码查看(xjl456852原创)

    idea添加了jdk环境后,却无法查看jdk源码,只能通过idea自带的反编译查看,看起来有些不爽. 下面来说一下如何设置,导入jdk源码,查看时通过源码查看jdk. 1.点击菜单 File -> ...

  3. windons杀死8080进程

    1,netstat -aon|findstr "8080" //8080端口号 2,taskkill -PID 2976 -F //2976 ,8080端口号对应的进程号

  4. js的undefined怎么判断

    window.undefined=window.undefined 如何理解呢?百度搜索:window.undefined=window.undefined 博客说是为了兼容老浏览器. 技巧: 调试时 ...

  5. Android圆弧背景

    代码改变世界 Android圆弧背景 <?xml version="1.0" encoding="utf-8"?><shape xmlns:a ...

  6. 【bzoj3231】[Sdoi2008]递归数列 矩阵乘法+快速幂

    题目描述 一个由自然数组成的数列按下式定义: 对于i <= k:ai = bi 对于i > k: ai = c1ai-1 + c2ai-2 + ... + ckai-k 其中bj和 cj  ...

  7. poj-2728Desert King(最优比率生成树)

    David the Great has just become the king of a desert country. To win the respect of his people, he d ...

  8. LA 并查集路径压缩

    题目大意:有n个节点,初始时每个节点的父亲节点都不存在.有两种操作 I u v:把点节点u的父亲节点设为v,距离为|u-v|除以1000的余数.输入保证执行指令前u没有父亲节点. E u:询问u到根节 ...

  9. 清清月儿.net学习技术资料网站

    原文发布时间为:2008-08-03 -- 来源于本人的百度文章 [由搬家工具导入] http://blog.csdn.net/21aspnet/

  10. 手动实现jQuery的toggle()效果

    有时候我们希望实现toggle()切换效果,但是切换的同时需要完成一些其他要做的事情.所以我们需要对jQuery的toggle()函数进行改造. 下面好test2()函数就是一个实现toggle效果的 ...