QML动画概述(几十篇相关博客)
QML提供了丰富的动画元素,说起动画,无非是给UI增光添彩罢了。在QML中,动画常常与State和Transition联系在一起,这几个概念(下面的例子中都用到了)都比较简单,相关介绍可查看Qt官方文档,网址如下:
http://doc.qt.io/qt-5/qtquick-statesanimations-topic.html
下面先列举几个QML动画元素,动画效果可“忘文生意”:
PropertyAnimation(常用)
AnchorAnimation
ColorAnimation
NumberAnimation
ParentAnimation
PathAnimation
RotationAnimation
Vector3dAnimation
SequentialAnimation
ParalleAnimation
PauseAnimation
SmoothedAnimation
SpringAnimation
PropertyAction(无动画效果)
ScriptAction
Behavior(设置默认动画)
常见的QML动画有三种表示方式,下面一一说明。
1、使用State和Transition
State改变属性值,Transition实现动画,例子如下:
- import QtQuick 2.2
- Item {
- id: container
- width: 360
- height: 360
- Rectangle {
- id: rect
- width: 100
- height: 100
- color: "blue"
- MouseArea {
- anchors.fill: parent
- // state属性值为空字符串时('')即默认状态
- onClicked: container.state == 'right' ? container.state = '' : container.state = 'right'
- }
- }
- states: State {
- name: "right"
- // rect水平移动
- PropertyChanges {
- target: rect
- x: 260
- }
- }
- transitions: Transition {
- // 数字(x坐标)动画,设置了easing的回弹效果和动画时间
- NumberAnimation {
- property: "x"
- easing.type: Easing.InOutBounce
- duration: 500
- }
- }
- }
2、使用Behavior
直接修改上面的例子,实现同样的动画效果,结果如下:
- import QtQuick 2.2
- Item {
- id: container
- width: 360
- height: 360
- Rectangle {
- id: rect
- width: 100
- height: 100
- color: "blue"
- // 看这里
- Behavior on x {
- NumberAnimation {
- easing.type: Easing.InOutBounce
- duration: 500
- }
- }
- MouseArea {
- anchors.fill: parent
- // 改变rect的x坐标
- onClicked: rect.x = (rect.x == 0 ? 260 : 0)
- }
- }
- }
3、其它
还是在上面例子的基础上修改以实现同样的效果,代码如下:
- import QtQuick 2.2
- Item {
- id: container
- width: 360
- height: 360
- Rectangle {
- id: rect
- width: 100
- height: 100
- color: "blue"
- // rect水平右移
- NumberAnimation on x {
- id: right
- running: false // false
- to: 260
- easing.type: Easing.InOutBounce
- duration: 500
- }
- // rect水平左移
- NumberAnimation on x {
- id: left
- running: false // false
- to: 0
- easing.type: Easing.OutInBounce // 换个easing动画效果
- duration: 500
- }
- MouseArea {
- anchors.fill: parent
- // 判断移动方向
- onClicked: rect.x == 0 ? right.running = true : left.running = true
- }
- }
- }
下面再来看一个有意思的例子,parallel和sequential动画:
- import QtQuick 2.2
- Item {
- id: container
- width: 360
- height: 360
- Rectangle {
- id: up
- width: 100
- height: 100
- color: "blue"
- // 并行动画,水平移动和颜色变化同时进行
- ParallelAnimation {
- id: parallel
- running: false
- PropertyAnimation {
- target: up
- property: "x"
- to: 260
- duration: 500
- }
- PropertyAnimation {
- target: up
- property: "color"
- to: "red"
- duration: 500
- }
- }
- MouseArea {
- anchors.fill: parent
- onClicked: parallel.running = true
- }
- }
- Rectangle {
- id: down
- width: 100
- height: 100
- color: "red"
- anchors.top: up.bottom
- // 串行动画,先进行水平移动,后进行颜色变化
- SequentialAnimation {
- id: sequential
- running: false
- PropertyAnimation {
- target: down
- property: "x"
- to: 260
- duration: 500
- }
- PropertyAnimation {
- target: down
- property: "color"
- to: "blue"
- duration: 500
- }
- }
- MouseArea {
- anchors.fill: parent
- onClicked: sequential.running = true
- }
- }
- }
关于QML动画,Qt官网文档也做了详细的介绍:
http://doc.qt.io/qt-5/qtquick-usecase-animations.html
http://doc.qt.io/qt-5/qtquick-statesanimations-animations.html
http://blog.csdn.net/ieearth/article/details/43986559
QML动画概述(几十篇相关博客)的更多相关文章
- 我的第一篇Markdown博客
我的第一篇Markdown博客 这是我第一次用Markdown写博客,发现还是比较好用的,加上Marsedit也支持了Markdown的博客预览,博客园也加了Markdown的格式支持,就更加方便了, ...
- HTML5 Canvas动画效果演示 - 流浪的鱼 - 博客频道 - CSDN.NET
HTML5 Canvas动画效果演示 - 流浪的鱼 - 博客频道 - CSDN.NET HTML5 Canvas动画效果演示
- Android相关 博客收藏
#1 Android 网络编程 参考博客 :http://blog.csdn.net/kieven2008/article/details/8210737 #2 Could not find com. ...
- Ceph相关博客、网站(256篇OpenStack博客)
官网文档: http://docs.ceph.com/docs/master/cephfs/ http://docs.ceph.com/docs/master/cephfs/createfs/ ( ...
- Socket网络编程--FTP客户端(60篇socket博客,而且都比较简单、深入浅出)
已经好久没有写过博客进行分享了.具体原因,在以后说. 这几天在了解FTP协议,准备任务是写一个FTP客户端程序.直接上干货了. 0.了解FTP作用 就是一个提供一个文件的共享协议. 1.了解FTP协议 ...
- 基于Laravel开发博客应用系列 —— 十分钟搭建博客系统
1.创建文章数据表及其模型(0:00~2:30) 我们已经在上一节中为博客项目完成了大部分准备工作,现在首先要做的就是为这个项目创建一个新的文章表 posts及该表对应的模型类 Post,使用如下Ar ...
- 第十六周博客作业 <西北师范大学| 周安伟>
第十六周作业 助教博客链接https://home.cnblogs.com/u/zaw-315/ 作业要求链接https://www.cnblogs.com/nwnu-daizh/p/10980707 ...
- 第十五周博客作业 <西北师范大学| 周安伟>
第十五周作业 助教博客链接https://home.cnblogs.com/u/zaw-315/ 作业要求链接https://www.cnblogs.com/nwnu-daizh/p/10946673 ...
- 第十二周博客作业 <西北师范大学| 周安伟>
第十二周作业 助教博客链接https://home.cnblogs.com/u/zaw-315/ 作业要求链接https://www.cnblogs.com/nwnu-daizh/p/10831971 ...
随机推荐
- FPGA综合优化
1 速度和面积 在全面优化水平将达到速度和面积RTL要利用逻辑拓扑的优势. 供FPGA由于在后端而言缺乏知识,门级优化.普通情况下更高的速度要求更高的并行性以及更大的面积,可是在某些特殊情况下并非这样 ...
- 【16.52%】【codeforces 733C】Epidemic in Monstropolis
time limit per test1 second memory limit per test256 megabytes inputstandard input outputstandard ou ...
- Linq知识小总结
一.投影操作符 Select Select操作符对单个序列或集合中的值进行投影. 返回 IEnumerable<类名> //查询语法 var query = from e in db.Em ...
- http_load测试初阶
http_load的标准的两个例子是: 1. http_load -parallel 5 -fetches 1000 urls.txt 2. http_load -ra ...
- Java--ConcurrentHashMap原理分析
一.背景: 线程不安全的HashMap 因为多线程环境下,使用Hashmap进行put操作会引起死循环,导致CPU利用率接近100%,所以在并发情况下不能使用HashMap. 效率低下的H ...
- 【STL】关联容器 — hashtable
C++ 11哈希表已被列入标准列.hashtable这是hash_set.hash_map.hash_multiset.hash_multimap的底层机制.即这四种容器中都包括一个hashtable ...
- SICP 锻炼 (1.40)解决摘要
SICP 锻炼1.40 是一个休闲的工作非常easy,但它看起来很复杂,单的一道题. 题目原题例如以下: 请定义一个过程cubic, 它和newtons-method过程一起使用在以下形式的表达式里: ...
- 用SendNotifyMessage代替PostMessage避免消息丢失(WIN7下消息队列的默认长度是10000,队列满后消息将被丢弃)
大家都知道PostMessage会丢消息,但是消息队列的大小是多少呢,下面做了一个测试. 代码: 1 unit Unit1; 2 3 interface 4 5 uses 6 Windows, M ...
- RDIFramework.NET框架SOA解(集Windows服务、WinForm形式和IIS发布形式)-分布式应用程序
RDIFramework.NET框架SOA解决方式(集Windows服务.WinForm形式与IIS形式公布)-分布式应用 RDIFramework.NET,基于.NET的高速信息化系统开发.整合框架 ...
- CentOS6.8环境安装oracle 11G
本节所讲内容: oracle11g基础环境配置 数据库的三种安装方式(图形.静默.克隆) http://db-engines.com REDHAT6.5安装oracle11.2.4 ORACLE11G ...