【Qt Quick】状态:State 使用
State
是 Qt Quick 中管理界面组件状态的关键工具。它允许我们定义组件的不同状态,并且在用户交互或事件发生时进行状态切换,从而实现属性、外观和行为的动态变化。通过使用 State
,可以避免复杂的条件逻辑,使代码更加简洁和可维护。
在本教程中,我们将详细讲解如何使用 State
、PropertyChanges
、when
和 Transition
实现组件状态的切换。通过一个完整的示例,您将学习如何响应用户交互事件、如何自动化状态转换,以及如何为状态切换添加动画。
创建一个示例:矩形的状态切换
我们从一个简单的例子开始,通过 Rectangle
的颜色和形状来展示状态的切换效果。
创建基础矩形
首先,我们创建一个矩形,它的初始颜色为红色,并放置在窗口中央:
import QtQuick 2.15
import QtQuick.Window 2.15Window {visible: truewidth: 640height: 480title: "State 示例"Rectangle {id: rect1width: 100height: 100color: "red"anchors.centerIn: parent}
}
定义状态 (State
)
使用 states
定义状态
为了实现矩形在不同状态下属性的变化,我们需要在 states
属性中定义状态。每个 State
都包含 name
和 PropertyChanges
,用来指定状态下组件的属性变化。
Rectangle {id: rect1width: 100height: 100color: "red"anchors.centerIn: parentstates: [State {name: "hovered"PropertyChanges {target: rect1color: "green"}},State {name: "clicked"PropertyChanges {target: rect1color: "blue"scale: 1.5}}]
}
在这个例子中:
- 当矩形处于
"hovered"
状态时,颜色变为绿色。 - 当矩形处于
"clicked"
状态时,颜色变为蓝色并放大 1.5 倍。
使用 MouseArea
进行状态切换
为了实现用户交互,使用 MouseArea
来捕获点击和悬停事件并触发状态切换。
MouseArea {id: mouseAreaanchors.fill: parenthoverEnabled: trueonClicked: {rect1.state = (rect1.state === "clicked") ? "" : "clicked";}onEntered: {rect1.state = "hovered";}onExited: {rect1.state = "";}
}
通过上述代码,我们实现了以下逻辑:
- 当用户点击矩形时,状态在
"clicked"
和默认状态之间切换。 - 当鼠标悬停时,状态切换为
"hovered"
,鼠标移开时恢复默认状态。
使用 when
自动控制状态
除了手动切换状态,Qt Quick 还允许我们使用 when
条件来自动根据某些条件进行状态转换。when
属性允许我们定义当条件满足时切换到某个状态,而无需手动设置。
使用 when
条件
我们可以通过 when
属性来自动设置状态,无需通过代码直接修改 state
属性。when
语句通过布尔表达式决定是否切换到该状态。
import QtQuick 2.15
import QtQuick.Window 2.15
Rectangle {id: rect1width: 100height: 100color: "red"anchors.centerIn: parent// 定义状态states: [State {name: "clicked"when: mouseArea.pressedPropertyChanges {target: rect1color: "blue"scale: 1.5}},State {name: "hovered"when: mouseArea.containsMousePropertyChanges {target: rect1color: "green"}}]// 鼠标区域MouseArea {id: mouseAreaanchors.fill: parenthoverEnabled: true}
}
在这个例子中:
- 当鼠标悬停在矩形上时,
when: mouseArea.containsMouse
触发"hovered"
状态,矩形颜色变为绿色。 - 当用户按下鼠标时,
when: mouseArea.pressed
触发"clicked"
状态,矩形颜色变为蓝色并放大。
这样使用 when
可以避免直接操作状态,状态的切换会根据用户操作自动完成。
添加过渡动画 (Transitions
)
基础过渡动画
为了使状态切换更加流畅,Qt Quick 提供了 Transition
元素,它允许我们为状态变化添加动画。通过 Transition
,状态之间的属性变化不会瞬间发生,而是会随着时间逐渐变化。
transitions: Transition {from: ""to: "clicked"NumberAnimation {properties: "scale,rotation"duration: 500}
}
在上面的代码中,当状态从默认状态切换到 "clicked"
时,scale
和 rotation
属性将在 500 毫秒内逐渐变化,使切换效果更自然。
针对不同状态的多重过渡
如果需要为不同状态间的切换定义不同的动画,可以定义多个 Transition
,并指定 from
和 to
状态。
transitions: [Transition {from: ""to: "hovered"ColorAnimation {target: rect1property: "color"duration: 300}},Transition {from: ""to: "clicked"NumberAnimation {properties: "scale"duration: 500}}
]
在这个例子中:
- 当切换到
"hovered"
状态时,矩形颜色的改变会在 300 毫秒内完成。 - 当切换到
"clicked"
状态时,scale
属性的变化会在 500 毫秒内完成。
状态扩展与嵌套
使用 extend
扩展状态
有时候我们希望一个状态基于另一个状态,并添加或修改部分属性。extend
关键字允许我们在一个状态的基础上扩展出新的状态。
State {name: "extendedClicked"extend: "clicked"PropertyChanges {target: rect1rotation: 90}
}
在这个例子中,extendedClicked
状态继承了 clicked
状态的所有属性变化,并且增加了 rotation
属性的变化。
嵌套状态
Qt Quick 允许在组件层次结构中嵌套状态,父组件的状态可以影响子组件的行为。我们可以在父组件中定义状态,并在子组件中使用 State
来响应这些状态变化。
总结
在本教程中,我们通过多个示例详细介绍了如何使用 Qt Quick 中的 State
管理组件的不同状态。我们讨论了 State
、PropertyChanges
、when
的使用,展示了如何通过用户交互事件触发状态切换,以及如何使用 Transition
添加动画效果。
State
机制极大地简化了组件状态管理的复杂性,让开发者能够更高效地实现 UI 中的状态切换。通过合理利用 when
条件和动画过渡,可以轻松创建用户体验更为友好的动态界面。
相关文章:
【Qt Quick】状态:State 使用
State 是 Qt Quick 中管理界面组件状态的关键工具。它允许我们定义组件的不同状态,并且在用户交互或事件发生时进行状态切换,从而实现属性、外观和行为的动态变化。通过使用 State,可以避免复杂的条件逻辑,使代码更加简洁和可维护…...

ICE/TURN/STUN/Coturn服务器搭建
ICE 当我们想要实现在公网环境下的语音/视频通话功能时,就需要用到ICE交互式连接建立。ICE不是一种协议,整合了 STUN 和 TURN 两种协议(用于 NAT 穿透)的框架。 ICE的主要目标是解决NAT(网络地址转换)穿越…...

ctf.bugku-eval
题目来源:eval - Bugku CTF 访问页面, 代码解释 <?phpinclude "flag.php"; //包含"flag.php"文件$a $_REQUEST[hello]; //从请求参数hello中获取值并赋给变量$a。 eval( "var_dump($a);"); //…...

Extreme Compression of Large Language Models via Additive Quantization阅读
文章目录 Abstract1. Introduction2. Background & Related Work2.1. LLM量化2.2. 最近邻搜索的量化 3.AQLM:Additive Quantization for LLMs3.1. 概述3.1.0 补充**步骤说明****举例说明** 3.2. 阶段1:代码的波束搜索3.3. 阶段2:码本更新3.4. 阶段3&…...

【虚拟化】内核级虚拟化技术KVM介绍,全/半虚拟化的区别,使用libvirt搭建虚拟化平台(go/java/c++)
【虚拟化】内核级虚拟化技术KVM介绍,全/半虚拟化的区别,使用libvirt搭建虚拟化平台(go/java/c) 文章目录 1、虚拟化技术分类与架构(KVM,Xen),全/半虚拟化的区别2、libvirt介绍3、使用…...
C++类成员变量的初始化
1、优先使用或{} 类的非静态数据成员在声明时,使用或{}进行初始化执行默认初始化,构造函数只处理一些特殊成员。 2、直接初始化 使用()进行初始化、new运算符和类构造函数的初始化列表。 3、拷贝初始化 使用进行初始化、函数传参、函数返回值。 隐式调用…...
Golang 中的强大 TUI 库 ——tview
在命令行界面下创建丰富的用户交互界面是许多开发者的需求,而 Golang 语言中有一个非常出色的 TUI(文本用户界面)库 ——tview。本文将详细介绍 tview 库,并与其他流行的 TUI 库进行对比,最后进行总结。 一、tview 库介…...

电层相关 -- 支路板与线路板
华为OTN产品系列支持 支路板、线路板分离架构 。支路/线路板和集中交叉单板配合使用,除了可以完成OTU单板功能外,还可通过集中交叉单板进行各级别ODUk颗粒业务调度, 实现更加灵活的电层信号调度及更高的带宽利用率。 支路板 功能 实现客户…...

leetcode 93.复原ip地址
1.题目要求: 2.题目代码: class Solution { public:vector<string> result;// 记录结果// startIndex: 搜索的起始位置,pointNum:添加逗点的数量void backtracking(string& s, int startIndex, int pointNum) {if (pointNum 3) { // 逗点数…...

AI+视频监控:EasyCVR安防平台赋能火电制造行业的视频智能管理方案
随着信息技术的飞速发展和智能制造的深入推进,火电制造行业作为国民经济的重要组成部分,正面临着智能化转型的迫切需求。为了提升生产效率、保障设备安全、优化管理流程,火电制造企业迫切需要引入先进的视频监控与人工智能技术。EasyCVR安防监…...
UIP协议栈 TCP Server Client通信成功案例
文章目录 这里边有相当好的 [UIP 文档资料,文档位置在仓库的UIP/uip doc ,括号内是仓库地址(https://gitee.com/free-people-in-time-and-space/net-work-learn-note.git )TCP Server1.main循环里做的事2.以下是main循环里相关函数…...

Android Studio Koala Feature Drop 稳定版现已推出
作者 / Android Studio 产品经理 Sandhya Mohan Android Studio Koala Feature Drop (2024.1.2) 现已推出!🐨 🔗 Android Studio https://developer.android.google.cn/studio 今年早些时候,我们宣布每个 Android Studio 动物版本…...

胤娲科技:AI评估新纪元——LightEval引领透明化与定制化浪潮
AI评估的迷雾,LightEval能否拨云见日? 想象一下,你是一位AI模型的开发者,精心打造了一个智能助手,却在最终评估阶段遭遇了意外的“滑铁卢”。 问题出在哪里?是模型本身不够聪明,还是评估标准太过…...

Python安装|PyCharm Professional 下载安装教程。2024最新版,亲测使用!
一、下载地址: 二、Python的下载及安装: 1、从上面网址进入Python官网 2、安装流程图: 双击已经下载好的python-*.*.*-amd64.exe文件,开始安装 最后就等它自己安装完成就好了 3、检验是否安装完成: windowsR快捷键…...
JavaSwitch控制流语句
在Java中,switch语句是一种控制流语句,用于根据变量的不同值执行不同的代码块。它提供了一种替代if-else语句的方式,使代码更简洁和易于阅读。以下是switch语句的基本语法和使用示例。 基本语法 switch (expression) {case value1:// 执行代码…...

PCL 3D-SIFT关键点检测(Z方向梯度约束
目录 一、概述 1.1原理 1.2实现步骤 1.3应用场景 二、代码实现 2.1关键函数 2.1.1 SIFT关键点检测 2.1.2 可视化函数 2.2完整代码 三、实现效果 PCL点云算法汇总及实战案例汇总的目录地址链接: PCL点云算法与项目实战案例汇总(长期更新&#…...

肺结节分割与提取系统(基于传统图像处理方法)
Matlab肺结节分割(肺结节提取)源程序,GUI人机界面版本。使用传统图像分割方法,非深度学习方法。使用LIDC-IDRI数据集。 工作如下: 1、读取图像。读取原始dicom格式的CT图像,并显示,绘制灰度直方图; 2、图像…...

ESP32 COAP 客户端观察者模式下,GET服务器的例程
目录 环境准备 示例代码 代码解释 初始化: CoAP 上下文和会话: 注册响应处理函数: 创建和发送 GET 请求: 处理响应: 主循环: 注意事项 ESP32 是一款功能强大的微控制器,支持多种通信协议,包括 CoAP(Constrained Application Protocol)。CoAP 是一种专为物联…...

【Kubernetes】常见面试题汇总(五十七)
目录 125. K8S 创建服务 status 为 ErrlmagePull? 126.不能进入指定容器内部? 特别说明: 题目 1-68 属于【Kubernetes】的常规概念题,即 “ 汇总(一)~(二十二)” 。 题目 …...
Java 设计模式 构建者模式
文章目录 1 概念2 使用方法1 创建步骤:2 使用步骤: 参考 1 概念 builder模式又叫建造者模式,属于创建型模式 作用:将一个复杂对象的构建与他的表示分离,可以一步一步构建对象,而不是使用构造函数构造一次…...

华为云AI开发平台ModelArts
华为云ModelArts:重塑AI开发流程的“智能引擎”与“创新加速器”! 在人工智能浪潮席卷全球的2025年,企业拥抱AI的意愿空前高涨,但技术门槛高、流程复杂、资源投入巨大的现实,却让许多创新构想止步于实验室。数据科学家…...
基础测试工具使用经验
背景 vtune,perf, nsight system等基础测试工具,都是用过的,但是没有记录,都逐渐忘了。所以写这篇博客总结记录一下,只要以后发现新的用法,就记得来编辑补充一下 perf 比较基础的用法: 先改这…...
C# SqlSugar:依赖注入与仓储模式实践
C# SqlSugar:依赖注入与仓储模式实践 在 C# 的应用开发中,数据库操作是必不可少的环节。为了让数据访问层更加简洁、高效且易于维护,许多开发者会选择成熟的 ORM(对象关系映射)框架,SqlSugar 就是其中备受…...
MySQL中【正则表达式】用法
MySQL 中正则表达式通过 REGEXP 或 RLIKE 操作符实现(两者等价),用于在 WHERE 子句中进行复杂的字符串模式匹配。以下是核心用法和示例: 一、基础语法 SELECT column_name FROM table_name WHERE column_name REGEXP pattern; …...

蓝桥杯3498 01串的熵
问题描述 对于一个长度为 23333333的 01 串, 如果其信息熵为 11625907.5798, 且 0 出现次数比 1 少, 那么这个 01 串中 0 出现了多少次? #include<iostream> #include<cmath> using namespace std;int n 23333333;int main() {//枚举 0 出现的次数//因…...
NPOI Excel用OLE对象的形式插入文件附件以及插入图片
static void Main(string[] args) {XlsWithObjData();Console.WriteLine("输出完成"); }static void XlsWithObjData() {// 创建工作簿和单元格,只有HSSFWorkbook,XSSFWorkbook不可以HSSFWorkbook workbook new HSSFWorkbook();HSSFSheet sheet (HSSFSheet)workboo…...

android13 app的触摸问题定位分析流程
一、知识点 一般来说,触摸问题都是app层面出问题,我们可以在ViewRootImpl.java添加log的方式定位;如果是touchableRegion的计算问题,就会相对比较麻烦了,需要通过adb shell dumpsys input > input.log指令,且通过打印堆栈的方式,逐步定位问题,并找到修改方案。 问题…...
掌握 HTTP 请求:理解 cURL GET 语法
cURL 是一个强大的命令行工具,用于发送 HTTP 请求和与 Web 服务器交互。在 Web 开发和测试中,cURL 经常用于发送 GET 请求来获取服务器资源。本文将详细介绍 cURL GET 请求的语法和使用方法。 一、cURL 基本概念 cURL 是 "Client URL" 的缩写…...
Kafka主题运维全指南:从基础配置到故障处理
#作者:张桐瑞 文章目录 主题日常管理1. 修改主题分区。2. 修改主题级别参数。3. 变更副本数。4. 修改主题限速。5.主题分区迁移。6. 常见主题错误处理常见错误1:主题删除失败。常见错误2:__consumer_offsets占用太多的磁盘。 主题日常管理 …...

Linux 下 DMA 内存映射浅析
序 系统 I/O 设备驱动程序通常调用其特定子系统的接口为 DMA 分配内存,但最终会调到 DMA 子系统的dma_alloc_coherent()/dma_alloc_attrs() 等接口。 关于 dma_alloc_coherent 接口详细的代码讲解、调用流程,可以参考这篇文章,我觉得写的非常…...