Qt Quick实现一个炫酷的折叠动画效果

2024-06-20 07:38

本文主要是介绍Qt Quick实现一个炫酷的折叠动画效果,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

demo来自 https://github.com/cjmdaixi/FlipAnimation

代码上传到了 csdn

文章目录

  • 效果图
  • 核心代码
  • 从中学习到了什么
    • ShaderEffectSource
    • Flipable
  • 感谢无私奉献的人

效果图

可以动态配置折叠次数
在这里插入图片描述

核心代码

FlipCards.qml

import QtQuick 2.9
import QtQuick.Controls 2.2Item {id: rootproperty int segments: 4property Item flipContentproperty Item coverItemproperty int expandSpeed: 300property int foldSpeed: 300property bool expanding: falseproperty bool folding: falseproperty bool folded: truewidth: flipCardWidthheight: flipCardHeightproperty real flipCardWidth: flipContent.widthproperty real flipCardHeight: flipContent.height / segmentsproperty int flipCardCount: segments - 1signal beginFold()signal beginExpand()ShaderEffectSource{id: bottomCardwidth: flipCardWidthheight: flipCardHeightanchors{left: parent.left; top: parent.top}sourceItem: flipContentsourceRect: Qt.rect(0, 0, flipCardWidth, flipCardHeight)z: flipContent.z + 1}Component{id: flipCardComponentFlipable{id: flipablewidth: root.flipCardWidthheight: root.flipCardHeightproperty alias expandAnimation: expandAnimationproperty alias foldAnimation: foldAnimationproperty alias backItem: backItemproperty alias frontItem: frontItemproperty int index: 0property bool isFirstCard: index === 0property bool isLastCard: index === root.flipCardCount - 1transform: Rotation {id: rotationorigin.x: flipable.width / 2origin.y: flipable.heightaxis.x: -1; axis.y: 0; axis.z: 0angle: 0}front: Item{id: frontItemanchors.fill: parentRectangle{anchors.fill: parentcolor: "white"}}back: ShaderEffectSource{id: backItemsourceItem: flipContentsourceRect: Qt.rect(0, flipCardHeight * (index + 1), flipCardWidth, flipCardHeight)anchors.fill: parent}NumberAnimation{id: expandAnimationduration: expandSpeedtarget: rotationproperty: "angle"to: 180onStarted: {root.height += flipCardHeight;if(isFirstCard){root.expanding = true;}}onStopped: {if(isLastCard){flipContent.layer.enabled = false;flipContent.visible = true;bottomCard.visible = false;root.expanding = false;root.folded = false;}}}NumberAnimation{id: foldAnimationduration: foldSpeedtarget: rotationproperty: "angle"to: 0onStarted: {if(isLastCard){flipContent.layer.enabled = true;flipContent.visible = false;bottomCard.visible = true;root.folding = true;}}onStopped: {root.height -= flipCardHeight;if(isFirstCard){root.folding = false;root.folded = true;}}}}}Loader{id: firstCardLoadersourceComponent: flipCardComponentonLoaded: {var prev = firstCardLoader.item;root.beginExpand.connect(prev.expandAnimation.start);flipContent.parent = root;flipContent.visible = false;coverItem.parent = prev.frontItem;prev.parent = bottomCard;for(var i = 1; i < root.flipCardCount; i++){//console.log("create flip card ", i);var card = flipCardComponent.createObject(prev.backItem, {"index": i});prev.expandAnimation.stopped.connect(card.expandAnimation.start);if(i === root.flipCardCount - 1){root.beginFold.connect(card.foldAnimation.start);}card.foldAnimation.stopped.connect(prev.foldAnimation.start);prev = card;}}}function expand(){root.beginExpand();}function fold(){root.beginFold();}
}

从中学习到了什么

ShaderEffectSource

ShaderEffectSource类型将sourceItem渲染为纹理并在场景中显示。sourceItem被绘制到纹理中,就像它是一个完全不透明的根项目一样。因此,sourceItem本身可以不可见,但仍会出现在纹理中。

ShaderEffectSource可以用作:

  • ShaderEffect中的纹理源。这允许您将自定义着色器效果应用于任何Qt Quick项目。
  • 用于复杂项目的缓存。复杂项目可以在纹理中渲染一次,然后可以自由设置动画,而无需每帧再次渲染复杂项目。
  • 不透明层。ShaderEffectSource允许将不透明度作为一个组应用于项目,而不是单独应用于每个项目。

用法如下:

  import QtQuick 2.0Rectangle {width: 200height: 100gradient: Gradient {GradientStop { position: 0; color: "white" }GradientStop { position: 1; color: "black" }}Row {opacity: 0.5Item {id: foowidth: 100; height: 100Rectangle { x: 5; y: 5; width: 60; height: 60; color: "red" }Rectangle { x: 20; y: 20; width: 60; height: 60; color: "orange" }Rectangle { x: 35; y: 35; width: 60; height: 60; color: "yellow" }}ShaderEffectSource {width: 100; height: 100sourceItem: foo}}}

效果:在这里插入图片描述
即使把foo隐藏掉,ShaderEffectSource 仍然可以显示。

Flipable

Flipable是一种可以在正面和背面之间明显“翻转”的物品,就像一张卡片。它可以与旋转、状态和过渡类型一起使用,以产生翻转效果。

front和back属性用于保存分别显示在可翻转项目正面和背面的项目。

用法如下,纸牌反转demo,效果如图:

在这里插入图片描述

flipable.qmlproject

import QmlProject 1.1Project {mainFile: "flipable.qml"/* Include .qml, .js, and image files from current directory and subdirectories */QmlFiles {directory: "."}JavaScriptFiles {directory: "."}ImageFiles {directory: "."}
}

Card.qml

import QtQuick 2.0Flipable {id: containerproperty alias source: frontImage.sourceproperty bool flipped: trueproperty int xAxis: 0property int yAxis: 0property int angle: 0width: front.width; height: front.heightfront: Image { id: frontImage }back: Image { source: "back.png" }state: "back"MouseArea { anchors.fill: parent; onClicked: container.flipped = !container.flipped }transform: Rotation {id: rotation; origin.x: container.width / 2; origin.y: container.height / 2axis.x: container.xAxis; axis.y: container.yAxis; axis.z: 0}states: State {name: "back"; when: container.flippedPropertyChanges { target: rotation; angle: container.angle }}transitions: Transition {ParallelAnimation {NumberAnimation { target: rotation; properties: "angle"; duration: 600 }SequentialAnimation {NumberAnimation { target: container; property: "scale"; to: 0.75; duration: 300 }NumberAnimation { target: container; property: "scale"; to: 1.0; duration: 300 }}}}
}

flipable.qml

import QtQuick 2.0
import "content"Rectangle {id: windowwidth: 480; height: 320color: "darkgreen"Row {anchors.centerIn: parent; spacing: 30Card { source: "content/9_club.png"; angle: 180; yAxis: 1 }Card { source: "content/5_heart.png"; angle: 540; xAxis: 1 }}
}

感谢无私奉献的人

这篇关于Qt Quick实现一个炫酷的折叠动画效果的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1077515

相关文章

java实现docker镜像上传到harbor仓库的方式

《java实现docker镜像上传到harbor仓库的方式》:本文主要介绍java实现docker镜像上传到harbor仓库的方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地... 目录1. 前 言2. 编写工具类2.1 引入依赖包2.2 使用当前服务器的docker环境推送镜像2.2

C++20管道运算符的实现示例

《C++20管道运算符的实现示例》本文简要介绍C++20管道运算符的使用与实现,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧... 目录标准库的管道运算符使用自己实现类似的管道运算符我们不打算介绍太多,因为它实际属于c++20最为重要的

Java easyExcel实现导入多sheet的Excel

《JavaeasyExcel实现导入多sheet的Excel》这篇文章主要为大家详细介绍了如何使用JavaeasyExcel实现导入多sheet的Excel,文中的示例代码讲解详细,感兴趣的小伙伴可... 目录1.官网2.Excel样式3.代码1.官网easyExcel官网2.Excel样式3.代码

python实现对数据公钥加密与私钥解密

《python实现对数据公钥加密与私钥解密》这篇文章主要为大家详细介绍了如何使用python实现对数据公钥加密与私钥解密,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 目录公钥私钥的生成使用公钥加密使用私钥解密公钥私钥的生成这一部分,使用python生成公钥与私钥,然后保存在两个文

浏览器插件cursor实现自动注册、续杯的详细过程

《浏览器插件cursor实现自动注册、续杯的详细过程》Cursor简易注册助手脚本通过自动化邮箱填写和验证码获取流程,大大简化了Cursor的注册过程,它不仅提高了注册效率,还通过友好的用户界面和详细... 目录前言功能概述使用方法安装脚本使用流程邮箱输入页面验证码页面实战演示技术实现核心功能实现1. 随机

Golang如何对cron进行二次封装实现指定时间执行定时任务

《Golang如何对cron进行二次封装实现指定时间执行定时任务》:本文主要介绍Golang如何对cron进行二次封装实现指定时间执行定时任务问题,具有很好的参考价值,希望对大家有所帮助,如有错误... 目录背景cron库下载代码示例【1】结构体定义【2】定时任务开启【3】使用示例【4】控制台输出总结背景

Golang如何用gorm实现分页的功能

《Golang如何用gorm实现分页的功能》:本文主要介绍Golang如何用gorm实现分页的功能方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录背景go库下载初始化数据【1】建表【2】插入数据【3】查看数据4、代码示例【1】gorm结构体定义【2】分页结构体

在Golang中实现定时任务的几种高效方法

《在Golang中实现定时任务的几种高效方法》本文将详细介绍在Golang中实现定时任务的几种高效方法,包括time包中的Ticker和Timer、第三方库cron的使用,以及基于channel和go... 目录背景介绍目的和范围预期读者文档结构概述术语表核心概念与联系故事引入核心概念解释核心概念之间的关系

C++11委托构造函数和继承构造函数的实现

《C++11委托构造函数和继承构造函数的实现》C++引入了委托构造函数和继承构造函数这两个重要的特性,本文主要介绍了C++11委托构造函数和继承构造函数的实现,具有一定的参考价值,感兴趣的可以了解一下... 目录引言一、委托构造函数1.1 委托构造函数的定义与作用1.2 委托构造函数的语法1.3 委托构造函

C++11作用域枚举(Scoped Enums)的实现示例

《C++11作用域枚举(ScopedEnums)的实现示例》枚举类型是一种非常实用的工具,C++11标准引入了作用域枚举,也称为强类型枚举,本文主要介绍了C++11作用域枚举(ScopedEnums... 目录一、引言二、传统枚举类型的局限性2.1 命名空间污染2.2 整型提升问题2.3 类型转换问题三、C