QML —— 顺序动画,足球落地示例(附完整源码)

效果

源码
cpp 复制代码
import QtQuick 2.12
import QtQuick.Window 2.12

Window
{
    visible: true
    width: 640
    height: 480
    title: qsTr("Hello World")

    MouseArea
    {
        anchors.fill: parent
        onClicked:{setSequentialAnimationState(true)}
    }

    Component.onCompleted:{setSequentialAnimationState(false)}
    Component.onDestruction:{setSequentialAnimationState(false)}

    function setSequentialAnimationState(b)
    {
        if(b)
        {
            if(!sequentialAnimation.running){sequentialAnimation.start()}
        }
        else
        {
             if(sequentialAnimation.running){sequentialAnimation.stop()}
        }
    }

    Image
    {
        id: ballImg
        source: "ball.jpeg"
        scale: 0.3
        y: -height
        anchors.horizontalCenter: parent.horizontalCenter

        SequentialAnimation on y
        {
            id: sequentialAnimation
            loops: Animation.Infinite
            NumberAnimation
            {
                id: fallNumberAnimation
                to: ballImg.parent.height - ballImg.height
                easing.type: Easing.OutBounce
                duration: 2000
            }

            PauseAnimation {duration: 1000}

            NumberAnimation
            {
                to: -ballImg.height
                easing.type: Easing.OutQuad
                duration: 500
            }

        }
    }
}

关注

笔者 - jxd

相关推荐
NiNi_suanfa9 小时前
【Qt】Qt 批量修改同类对象
开发语言·c++·qt
mengzhi啊10 小时前
c++11的变参模板和c++17的左折叠
qt
路痴楷12 小时前
无法定位程序输入点问题
c++·qt·visual studio
Source.Liu12 小时前
【LibreCAD】 RS_Units 类完整解析
c++·qt·rust
偶像你挑的噻13 小时前
2.Qt-基础核心以及信号与槽
开发语言·qt
爱吃巧克力的程序媛18 小时前
Qt 异步编程---概述
开发语言·qt
天涯路s19 小时前
qt怎么自定义日志
开发语言·qt
四维碎片21 小时前
【Qt】QTimer 学习笔记总结
笔记·qt·学习
qq_401700411 天前
理解与优化Qt信号槽机制提高性能优化
qt
蚂蚁取经1 天前
Qt C++ 小部件 QCustomPlot 的使用
c++·qt·信息可视化