QML动画(Animator)

news2025/7/18 19:38:26

在Qt5.2之后,引入Animator动画元素。这种方式可以直接所用于Qt Quick的场景图形系统,这使得基于Animator元素的动画及时在ui界面线程阻塞的情况下仍然能通过图形系统的渲染线程来工作,比传统的基于对象和属性的Animation元素能带来更好的用户视觉体验。

Animator (动画器)

动画完成后,QML 属性的值将更新。动画运行时不会更新该属性。

动画器类型可以像任何其他动画类型一样使用。

属性: 

duration持续时间
easing缓和
from开始
to结束
target对象

常用的动画师:

XAnimatorX动画器
YAnimatorY动画器
ScaleAnimator缩放动画器
OpactityAnimator透明度动画器
RotationAnimator旋转动画器
UnifromAnimator同一动画器

例子:

Rectangle{
        id:rect1
        width: 100;height:100;x:100;y:100;color: "lightBlue"
        XAnimator on x{   //x轴移动
            from: 100
            to:300
            duration:5000
            loops: Animator.Infinite
        }
        YAnimator on y{   //y轴移动
            from: 100
            to:300
            duration:5000
            loops: Animator.Infinite
        }
        RotationAnimator on rotation {  //旋转
            from:0
            to:360
            duration: 5000
            loops:Animator.Infinite
        }
        ScaleAnimator on scale {   //缩放
            from:0.5
            to:1.5
            duration: 5000
            loops:Animator.Infinite
        }
        OpacityAnimator on opacity {  //透明度
            from:0.1
            to:1.0
            duration: 5000
            loops:Animator.Infinite
        }
    }

Rotation(旋转) 

旋转类型提供了一种通过旋转类型转换来旋转项目的方法

提供2D旋转,也提供3D旋转

 属性:

angle角度

axis.x

axis.y

axis.z

旋转的轴

origin.x

origin.y

旋转的起点

使用格式:

transfron:Rotation{
    .......
}
transfrom属性主要用于 Rotation

 2d效果:无需指定轴,因为默认轴是 z 轴 ()

Rectangle{
        id:rect1
        width: 100;height:100;x:200;y:200
        color: "green"
        transform: Rotation{
            origin.x:0;origin.y:0  //起点0,0
            angle:50               //旋转50°
        }
    }

3d效果:

 Rectangle{
        id:rect1
        width: 100;height:100;x:200;y:200
        color: "green"
        transform: Rotation{
            origin.x:0;origin.y:0
            axis{  //沿着y轴旋转
                x:0
                y:1
                z:0
            }
            angle:50
        }
    }

AnimatedImage(动画图像)

AnimatedImage 类型扩展了 Image 类型的功能,提供了一种播放存储为包含一系列帧的图像(如存储在 GIF 文件中的帧)的图像的动画的方法

属性:

currentFrame当前帧
frameCount帧数
paused暂停
playing保存动画图像是否正在播放
source播放资源
speed播放速度

3D旋转图像:

Rectangle{
        id:rect1
        width: 100;height:100;x:200;y:200
        color: "green"

        AnimatedImage{
            id:image1
            source:"qrc:/image/123456.gif"
        }

        transform: Rotation{
            origin.x:0;origin.y:0
            axis{  //沿着y轴旋转
                x:0
                y:1
                z:0
            }
            NumberAnimation on angle{
                from:20
                to:90
                duration: 5000
                loops:Animation.Infinite
            }
        }
    }

AnimatedSprite(动画精灵)

动画精灵提供对动画的渲染和控制,这些动画在同一图像文件中作为多个帧提供。您可以以固定速度、显示器的帧速率播放它,也可以手动前进和控制进度

属性:

currentFrame当前帧
finishBehavior完成行为
frameCount帧数
frameDuration帧持续时间
frameHeight框架高度
frameWidth框架宽度
frameRate帧率
frameSync帧同步
frameX第一帧的图像文件中的 X 坐标
frameY第一帧的图像文件中的 Y 坐标
interpolate

true,则在精灵帧之间将进行插值,以使动画看起来更平滑(默认为true)

loops循环(默认值为AnimatedSprite.Infinite)
paused暂停
reverse动画将反向播放
runing是否具有动画效果(默认值为 true)
socure资源

函数:

advance()精灵动画推进一帧
pause()暂停精灵动画
restart()停止,然后启动精灵动画
resume()恢复精灵动画
start()启动精灵动画 (Qt 5.15)
stop()停止精灵动画(Qt 5.15)

例子:

 把这个分成4帧,来进行播放。

Rectangle{
        width: 260;height: 260
        AnimatedSprite{
            anchors.fill:parent
            running: true
            source:"qrc:/image/animatedsprite-loading.png"
            frameWidth: 64
            frameHeight: 64
            frameCount: 4//分成4部分
            frameDuration: 500
            interpolate: false
        }
    }

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/396436.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

CAD如何导入其他图纸的打印设置?CAD打印设置导入步骤

CAD打印设置怎么导入?这个问题相信很多设计师小伙伴在CAD图纸打印过程中都曾想到过,但不知道CAD如何导入其他图纸的打印设置,今天小编就以浩辰CAD软件为例来给大家分享一下CAD打印设置导入的具体操作步骤,一起来看看吧&#xff01…

把第三方sdk放在thinkphp的那个目录

ThinkPHP5.1 如何自动加载第三方SDK(非composer包 )注意:这里只是针对于非Composer 安装包的自动加载的实现,能用composer安装的自动跳过。由于ThinkPHP5.1 严格遵循PSR-4规范,不再建议手动导入类库文件,所…

应用实战|微信小程序开发示例--多人聊天互动空间

“超能力”数据库~拿来即用,应用开发人员再也不用为撰写API而发愁。MemFire Cloud 为开发者提供了简单易用的云数据库(表编辑器、自动生成API、SQL编辑器、备份恢复、托管运维),很大地降低开发者的使用门槛。 本示例是…

[Web]——限流

限流概念:什么是限流呢?限流是限制到达系统的并发请求数量,保证系统能够正常响应部分用户请求,而对于超过限制的流量,则通过拒绝服务的方式保证整体系统的可用性。限流的分类:根据作用范围可以分为单机限流和分布式限流…

Delphi 实现HTML邮件发送

在我们的邮箱里,经常收到HTML格式的邮件。每注册一个网站的时候,总会收到一些他们发来的邮件,打开一后发现和一个网页一样,有图片、链接、文字,甚至有的还有声音和视频和交互。那我们想知道我们怎么才可以给朋友发送这…

【FLY】Java知识点总结

目录认识Java概念图名词解释历史版本基础知识编程规范关键字数据类型运算符数组Stringequals与流程控制引用数据结构常用数据结构HashMapLinkedHashMapWeakHashMapIdentityHashMapEnumMapTreeMapCopyOnWriteArrayList面向对象类反射注解IO异常线程EffectiveJava8JVM运行时数据区…

MXNet的机器翻译实践《编码器-解码器(seq2seq)和注意力机制》

机器翻译就是将一种语言翻译成另外一种语言,输入和输出的长度都是不定长的,所以这里会主要介绍两种应用,编码器-解码器以及注意力机制。编码器是用来分析输入序列,解码器用来生成输出序列。其中在训练时,我们会使用一些…

centos7安装教程

1.点击文件–新建虚拟机 2.根据图片一直下一步或者做一些改动 3. 点击自定义硬件,点击浏览选中下载好的ISO文件 4.配置完成后启动虚拟机 5.选择语言,中英文都可,按需求选择 6.进行设置目标位置,配置分区 7.选择网络和主机名 8.配置…

.net6 web api使用EF Core,根据model类自动生成表

1.安装EF Core和mysql数据库的nuget包 Microsoft.EntityFrameworkCore Pomelo.EntityFrameworkCore.MySql 2.创建models文件夹,在文件夹下创建实体类 public class Users{public int Id { get; set; }[Column(TypeName "varchar(200)"), Required]publ…

Streaming systems 第三章中文

Chapter 3. Watermarks GIthub链接,欢迎志同道合的小伙伴一起翻译 到目前为止,我们一直从pipeline设计者或数据科学家的角度来研究流处理。第二章介绍了水印,对事件时间处理中发生的位置和处理时间中结果何时输出的基本问题做了一部分回答。…

制造企业数字化工厂建设步骤的建议

随着工业4.0、中国制造2025的深度推进,越来越多的制造企业开始迈入智能制造的领域,那数字工厂要从何入手呢? 数字工厂规划的核心,也正是信息域和物理域这两个维度,那就从这两个维度来进行分析,看如何进行数…

MySQL架构篇

一、进阶学习环境说明 1.1 MySQL服务器环境 Linux虚拟机:CentOS 7 MySQL:MySQL5.7.30 在Linux服务器中安装MySQL: ps.如果有自己的云服务器,可忽略前两步,直接进行第三步 1.2 服务器日志文件说明 MySQL是通过文件系统对…

论文投稿指南——中文核心期刊推荐(经济管理)

【前言】 🚀 想发论文怎么办?手把手教你论文如何投稿!那么,首先要搞懂投稿目标——论文期刊 🎄 在期刊论文的分布中,存在一种普遍现象:即对于某一特定的学科或专业来说,少数期刊所含…

什么蓝牙耳机好用戴着舒适?佩戴舒适音质好的无线蓝牙耳机

戴耳机时间长会导致耳朵痛,时间长了对我们的听力还有影响。一款佩戴舒适的耳机更贴合耳朵的设计,能够带来更加优质的聆听体验,下面甄选出了几款佩戴比较舒适的耳机推荐,音质还非常出众。 一、南卡小音舱蓝牙耳机 单耳重量&#x…

Protobuf 使用和原理

文章目录1. protobuf 简介1.1. 发展背景1.2. 优缺点1.2.1. 优点1.2.2. 缺点2. 使用2.1. 消息类型2.1.1. 字段限制2.1.2. 数据类型2.1.3. 分配字段编号2.1.4. 保留字段2.1.5. 默认字段规则2.1.6. 枚举2.2. Protobuf 工作流程2.2.1 编译proto文件2.3. 使用建议3. 原理3.1. 编码格…

抓包工具fiddler详细使用教程

各位做测试的同学想必对抓包工具fiddler并不陌生,但是很多同学可能没有总结过它的用法,下面我总结了fiddler一些常用的用法。 Web端抓包配置 打开Fiddler,Tools -> Fiddler Options -> HTTPS 配置完后记得要重启Fiddler 选中Decrpt …

第2章 线程安全与共享资源竞争

第2章 线程安全与共享资源竞争 2.1 synchronized同步介绍 synchronized要解决的是共享资源冲突的问题。当共享资源被任务使用时,要对资源提前加锁。所有任务都采用抢占模式,即某个任务会抢先对共享资源加上第一把锁。如果这是一个排他锁,…

汇编指令学习(LOOP)

一、xor异或操作,相同为0,不同为1xor eax,eaxeax异或eax,相同为0,并把结果存放到eax,简单说该语句就是想eax寄存器清零。二、ECX,计数器mov ecx,0x3将ecx寄存器设置为3三、DEC减一操作dec ecxecx寄存器的值…

扬帆优配|昔日白马股濒临退市,却6天5涨停!ST股突然集体爆发

尽管再度重申“公司股票将被停止上市”,但3月8日早间,*ST辅仁股价仍是在开盘后快速封住涨停板。这已是该公司近6个买卖日来,第5次呈现涨停。 无独有偶,8日早间ST东瀛也在此前多次涨停后,再度呈现近4%的涨幅。而就在7日…

图像的读取与保存

图像是由一个个像素点组成,像素点就是颜色点,而颜色最简单的方式就是用RGB或RGBA表示图像保存图像将像素信息按照 一定格式,一定顺序(即编码) 存在硬盘上的 二进制文件 中保存图像需要以下必要信息:1. 文件…