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实现检查多个时间段是否有重合

《Java实现检查多个时间段是否有重合》这篇文章主要为大家详细介绍了如何使用Java实现检查多个时间段是否有重合,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 目录流程概述步骤详解China编程步骤1:定义时间段类步骤2:添加时间段步骤3:检查时间段是否有重合步骤4:输出结果示例代码结语作

使用C++实现链表元素的反转

《使用C++实现链表元素的反转》反转链表是链表操作中一个经典的问题,也是面试中常见的考题,本文将从思路到实现一步步地讲解如何实现链表的反转,帮助初学者理解这一操作,我们将使用C++代码演示具体实现,同... 目录问题定义思路分析代码实现带头节点的链表代码讲解其他实现方式时间和空间复杂度分析总结问题定义给定

Java覆盖第三方jar包中的某一个类的实现方法

《Java覆盖第三方jar包中的某一个类的实现方法》在我们日常的开发中,经常需要使用第三方的jar包,有时候我们会发现第三方的jar包中的某一个类有问题,或者我们需要定制化修改其中的逻辑,那么应该如何... 目录一、需求描述二、示例描述三、操作步骤四、验证结果五、实现原理一、需求描述需求描述如下:需要在

如何使用Java实现请求deepseek

《如何使用Java实现请求deepseek》这篇文章主要为大家详细介绍了如何使用Java实现请求deepseek功能,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 目录1.deepseek的api创建2.Java实现请求deepseek2.1 pom文件2.2 json转化文件2.2

python使用fastapi实现多语言国际化的操作指南

《python使用fastapi实现多语言国际化的操作指南》本文介绍了使用Python和FastAPI实现多语言国际化的操作指南,包括多语言架构技术栈、翻译管理、前端本地化、语言切换机制以及常见陷阱和... 目录多语言国际化实现指南项目多语言架构技术栈目录结构翻译工作流1. 翻译数据存储2. 翻译生成脚本

如何通过Python实现一个消息队列

《如何通过Python实现一个消息队列》这篇文章主要为大家详细介绍了如何通过Python实现一个简单的消息队列,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 目录如何通过 python 实现消息队列如何把 http 请求放在队列中执行1. 使用 queue.Queue 和 reque

Python如何实现PDF隐私信息检测

《Python如何实现PDF隐私信息检测》随着越来越多的个人信息以电子形式存储和传输,确保这些信息的安全至关重要,本文将介绍如何使用Python检测PDF文件中的隐私信息,需要的可以参考下... 目录项目背景技术栈代码解析功能说明运行结php果在当今,数据隐私保护变得尤为重要。随着越来越多的个人信息以电子形

使用 sql-research-assistant进行 SQL 数据库研究的实战指南(代码实现演示)

《使用sql-research-assistant进行SQL数据库研究的实战指南(代码实现演示)》本文介绍了sql-research-assistant工具,该工具基于LangChain框架,集... 目录技术背景介绍核心原理解析代码实现演示安装和配置项目集成LangSmith 配置(可选)启动服务应用场景

使用Python快速实现链接转word文档

《使用Python快速实现链接转word文档》这篇文章主要为大家详细介绍了如何使用Python快速实现链接转word文档功能,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 演示代码展示from newspaper import Articlefrom docx import

前端原生js实现拖拽排课效果实例

《前端原生js实现拖拽排课效果实例》:本文主要介绍如何实现一个简单的课程表拖拽功能,通过HTML、CSS和JavaScript的配合,我们实现了课程项的拖拽、放置和显示功能,文中通过实例代码介绍的... 目录1. 效果展示2. 效果分析2.1 关键点2.2 实现方法3. 代码实现3.1 html部分3.2