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

QML 实现一个动态的启动界面

QML 实现一个动态的启动界面

  • 一、效果查看
  • 二、源码分享
  • 三、所用到的资源下载

一、效果查看

在这里插入图片描述

二、源码分享

工程结构
在这里插入图片描述

main.qml

import QtQuick
import QtQuick.Controls
import QtQuick.Dialogs
import Qt.labs.platformWindow {id:windowwidth: 640height: 400visible: truetitle: qsTr("Hello World")property int imageCnt: 1Rectangle{anchors.fill: parentgradient: Gradient{orientation: Gradient.VerticalGradientStop { position: 0.0; color: "#4bb6ac" }GradientStop { position: 0.5; color: "#3edabd" }GradientStop { position: 1.0; color: "#24efc0" }}}Timer{interval: 2000repeat: truerunning:trueonTriggered: {var w = Qt.createComponent("DynamicImage.qml")if (w.status === Component.Ready) {var image = "qrc:/image/image"+imageCnt+".svg";imageCnt += 1if(imageCnt > 10)imageCnt = 1var endX = Math.floor(Math.random()*window.width);console.log(image,endX)var item = w.createObject(window,{x:window.width/2-50,y:window.height,width:100,height:100,source:image,stopX:endX,stopY:-150,originX:0,originy:50,moveDuration:15000,rotationDuration: 5000,running: true});console.log("create:"+item)item.moveFinished.connect(()=>{item.destroy()console.log("destroyed:"+item)})}else console.error("create component falied!");}}Text{id:btnwidth: 200height: 100z:1anchors.centerIn: parenttext: "正在启动中...请稍后!"color:"white"horizontalAlignment: Text.AlignHCenterverticalAlignment: Text.AlignVCenterfont.pixelSize: 30font.bold: truefont.italic: true}}

DynamicImage.qml

//DynamicImage.qml
import QtQuick
import QtQuick.ControlsImage{id:rootproperty int stopX: 0property int stopY: 0property alias originX: rotation.origin.xproperty alias originy: rotation.origin.yproperty int moveDuration: 5000property int rotationDuration: 5000property bool running: falsesignal moveFinished()transform: Rotation{id:rotationaxis.x: 0axis.y: 0axis.z: 1}RotationAnimation{running: root.runningtarget: rootfrom:0to:360loops:Animation.Infiniteduration: rotationDuration}ParallelAnimation{id:animrunning:root.runningNumberAnimation{target: rootproperties: "x"from:root.xto:stopXduration: moveDuration}NumberAnimation{target: rootproperties: "y"from:root.yto:stopYduration: moveDuration}onFinished: {moveFinished()console.log("onFinished")}}Component.onDestruction: {//console.log("onDestroyed")}
}

三、所用到的资源下载

本博文最前面下载。

http://www.lryc.cn/news/540684.html

相关文章:

  • 智能预警系统标准化处理流程
  • Unity游戏制作中的C#基础(4)数组声明和使用
  • tailwindcss学习03
  • QML Component 与 Loader 结合动态加载组件
  • Visual studio 2022 将打开文件的方式由单击改为双击
  • 网络工程师 (49)UDP协议
  • 了解大数据
  • 命令模式
  • 解放大脑!用DeepSeek自动生成PPT!
  • GUI编程(window系统→Linux系统)
  • 互推机制在开源AI智能名片2+1链动模式S2B2C商城小程序源码推广中的应用探索
  • Pytorch实现之特征损失与残差结构稳定GAN训练,并训练自己的数据集
  • ES6相关操作(2)
  • 自动化办公|xlwings生成图表
  • 大模型知识蒸馏技术(5)——在线蒸馏
  • Java 条件语句
  • 用JMeter给要登录的操作做压力测试
  • 算法的数学基础
  • flowable适配达梦数据库
  • VScode C语言学习开发环境;运行提示“#Include错误,无法打开源文件stdio.h”
  • DeepSeek企业级部署实战指南:从服务器选型到Dify私有化落地
  • 自制简单的图片查看器(python)
  • RD-搭建测试环境
  • 从零搭建微服务项目Base(第5章——SpringBoot项目LogBack日志配置+Feign使用)
  • 【深度学习】使用飞桨paddle实现波士顿房价预测任务
  • 钉钉多维表:数据管理与协作的新篇章
  • 高级推理的多样化推理与验证
  • 深入理解 MySQL 8 C++ 源码:SELECT MOD(MONTH(NOW()), 2) 的函数执行过程
  • 【算法系列】leetcode1419 数青蛙 --模拟
  • 蓝桥杯 Java B 组之背包问题、最长递增子序列(LIS)