当前位置: 首页 > article >正文

qml SpringAnimation详解

1. 概述

SpringAnimation 是 Qt Quick 中用于模拟弹簧效果的动画类。它通过模拟物体在弹簧力作用下的反应,产生一种振荡的动画效果,常用于模拟具有自然回弹、弹性和振动的动态行为。这种动画效果在 UI 中广泛应用,特别是在拖动、拉伸、回弹等交互效果上,能带来更具生动感和真实感的体验。

SpringAnimation 的效果模拟了弹簧物理行为,它可以在给定的目标位置周围反复来回震荡,直到平稳停止。这个类特别适用于一些具有“弹性”或者“回弹”特征的动画。

2. 重要属性
  • damping:阻尼系数,表示系统在振荡过程中能量消耗的程度。较高的阻尼值会使振荡更快停止,较低的阻尼值则会使振荡持续更久。常用的值范围是 0 到 1,0 表示没有阻尼,1 表示快速停止。

  • stiffness:弹性刚度,表示弹簧的硬度。刚度越大,弹簧的恢复力越强,物体的回弹会更强烈。通常,较高的刚度使动画效果更加紧凑和迅速,较低的刚度则会产生更柔和的回弹效果。

  • from:动画的起始值。表示动画从哪个值开始。

  • to:动画的目标值。表示动画最终的目标位置或状态。

  • duration:动画的持续时间。通过该属性可以控制弹簧动画的时间长度。通常,SpringAnimation 会根据物理效果和参数来计算动画实际的持续时间。

  • velocity:初始速度。这个属性控制动画的起始速度,可以通过这个属性调整动画的起始动能。

  • running:表示动画是否正在运行的布尔值。可以通过该属性获取当前动画的状态。

3. 重要方法
  • start():启动弹簧动画,从当前的 from 值到目标 to 值进行动画播放。

  • pause():暂停动画。暂停时,动画保持当前位置,且不会继续进行。

  • resume():恢复暂停的动画,继续从暂停的位置进行播放。

  • stop():停止动画,强制动画结束,并将其重置到初始状态。

4. 重要信号
  • runningChanged:当动画的运行状态发生变化时触发。例如,从运行状态变为暂停状态,或从暂停状态恢复为运行状态。

  • finished:当动画完成时触发,表示弹簧动画已经到达目标位置并停止。

  • paused:当动画暂停时触发。

  • stopped:当动画被停止时触发,表示动画被强制终止。

5. 常用枚举类型
  • Easing.Type:缓动类型枚举,常用于控制动画的加速和减速效果。SpringAnimation 通常与其他动画类一起使用时可以搭配使用该枚举。
    • Easing.Linear:匀速。
    • Easing.In:加速。
    • Easing.Out:减速。
    • Easing.InOut:开始和结束都加速和减速。
Window {
    visible: true
    width: 300
    height: 300

    Item {
        width: 300; height: 300

        Rectangle {
            id: rect
            width: 50; height: 50
            color: "red"

            Behavior on x { SpringAnimation { spring: 2; damping: 0.2 } }
            Behavior on y { SpringAnimation { spring: 2; damping: 0.2 } }
        }

        MouseArea {
            anchors.fill: parent
            onClicked: {
                rect.x = mouse.x - rect.width/2
                rect.y = mouse.y - rect.height/2
            }
        }
    }
}

觉得有帮助的话,打赏一下呗。。

           

需要商务合作(定制程序)的欢迎私信!! 


http://www.kler.cn/a/488829.html

相关文章:

  • 基于华为ENSP的OSPF状态机、工作过程、配置保姆级别详解(2)
  • 何为“正则表达式”!
  • [大模型]本地离线运行openwebui+ollama容器化部署
  • 如何设计一个注册中心?以Zookeeper为例
  • PLC实现HTTP协议JSON格式数据上报对接的参数配置说明
  • LabVIEW软件Bug的定义与修改
  • 【AI-22】深度学习框架中的神经网络2
  • 关于Java代理模式的面试题目及其答案
  • C++语言的学习路线
  • Kafka的Partition故障恢复机制与HW一致性保障-Epoch更新机制详解
  • WebRtc05:设备管理
  • HOW - Form 表单确认校验两种模式(以 Modal 场景为例)
  • Eureka缓存机制
  • RabbitMQ 在 Go 中的核心方法详解
  • 【AIGC-ChatGPT进阶提示词指令】命运之轮:一个融合神秘与智慧的对话系统设计
  • 安科瑞Acrel-1000DP分布式光伏监控系统在浙江安吉成3234.465kWp分布式光伏发电项目中的应用
  • 在 Ubuntu 上对 Nginx 进行源码编译的详细指南
  • 代码随想录刷题day04|(数组篇)209.长度最小的子数组
  • PDF转文本以及转图片:itextpdf
  • 【EXCEL 向下合并制定列的空白内容】
  • C++例程:使用I/O模拟IIC接口(6)
  • Win10本地部署大语言模型ChatGLM2-6B
  • [豆包MarCode AI 刷题] 算法题解 Java 青训入营考核 五题打卡第三天
  • 网络安全:守护数字世界的防线
  • 【react-pdf】实现在线pdf加载——翻页加载和下拉滚动加载
  • Vue.js组件开发-实现滚动加载下一页