Qt6 Qt Quick UI原型学习QML第二篇

Qt6 Qt Quick UI原型学习QML第二篇

  • 界面效果
  • QML语法
  • 语法讲解
    • 核心要素
    • 项目元素
    • 矩形元素
    • 文本元素
    • 图像元素
    • MouseArea元素


在这里插入图片描述

界面效果

在这里插入图片描述
在这里插入图片描述

QML语法

import QtQuick 2.12
import QtQuick.Window 2.12Window {id: rootvisible: truewidth: 640height: 480title: qsTr("QML学习第二篇")//  填充矩形Rectangle {id: rect1    // id: 为矩形对象指定唯一的标识符。在其他部分引用该矩形时使用。x: 12 ; y: 12width: 76; height: 96// 随机值颜色 矩形填充颜色color: Qt.rgba(Math.random(), Math.random(),Math.random(), 1)Text {text: "矩形1"}// 隐藏矩形2 在单击矩形1时MouseArea {id: areawidth: parent.width ; height: parent.heightonClicked: rect2.visible = !rect2.visible}}// 边框圆角矩形Rectangle {id: rect2x:112; y: 12width: 100; height: 96// 随机值颜色 矩形边框颜色border.color: Qt.rgba(Math.random(), Math.random(),Math.random(), 1)// 边框粗细border.width: 2radius: 8Text {text: "矩形2"}Rectangle {id: buttonx: rect2.x + 2; y : rect2.y + 10width: 50; height: 20color: 'lightsteelblue'border.color: 'slategrey'// 设置当前元素在父元素中居中显示的属性。anchors.centerIn: parentText {anchors.centerIn: parenttext: "Start"}MouseArea {// 填充整个父元素的范围anchors.fill: parentonClicked: {status.text = "Button clicked!"}}}Text {id :statusx: button.x ; y:70text: "Waiting ..."horizontalAlignment: Text.AlignLeft}}// 渐变矩形Rectangle {id: rect3x:12; y: rect1.height + 20width: 76 ; height: 96// gradient: 矩形的渐变填充。通过Gradient对象进行设置,该对象定义了一个渐变效果。gradient: Gradient {// position表示渐变颜色变化的位置,取值范围是0到1,可以超过1,表示在矩形外部延伸渐变效果。// 位置标记y轴上的位置(0 =顶部,1 =底部)GradientStop { position: 0.0; color: "#ff0000"}GradientStop { position: 0.5; color: "#00ff00"}GradientStop { position: 1.0; color: "#000000"}}Text {text: "矩形3"}}// 文本元素Text {x : (root.width-width)/2 + 60; y : 100width: root.width/2; height: 30text: "文本可以向两边和中间对齐horizontalAlignment和verticalAlignment属性。要进一步增强文本呈现,可以使用style和styleColor属性,该属性允许您以轮廓、凸起和凹陷模式呈现文本。"color: "#303030"font.family: "Ubuntu"font.pixelSize: 18horizontalAlignment: Text.AlignHCenterverticalAlignment: Text.AlignVCenter// 这elide属性允许您将省略位置设置在文本的左侧、右侧或中间。//elide: Text.ElideMiddle  // 你 ... 好// 文本过长自动换行wrapMode: Text.WordWrap// 红色 凹陷的 文本样式style: Text.SunkenstyleColor: '#FF4444'}// 图像元素Image {id: pic1x: 12; y: rect1.height + rect3.height + 30source: "pic//search.png"sourceSize: Qt.size(40,40)// fillMode: 图像的填充模式。这里设置为Image.PreserveAspectCrop,表示在保持图像长宽比的情况下,缩放图像并裁剪以填充图像元素的大小。fillMode: Image.PreserveAspectCrop// clip: 是否对图像进行裁剪。这里设置为true,表示在图像元素的边界之外的部分将被裁剪掉。clip: true}Rectangle {id: btx: 12; y: rect1.height + rect3.height + pic1.height + 50width: 116; height: 50color: "lightsteelblue"border.color: "slategrey"/* property alias text: label.text:这行代码为root矩形定义了一个公开的text属性,通过alias关键字将其与内部的label.text属性进行了绑定。这允许在外部可以直接访问和修改root矩形的文本内容 */property alias text: label.textText {id: labelanchors.centerIn: parenttext: "开始"}// 鼠标范围信号MouseArea {anchors.fill: parentonClicked: {label.text = "结束"}}}
}

语法讲解

核心要素

元素可以分为视觉元素和非视觉元素。视觉元素(如Rectangle)具有几何形状,并且通常在屏幕上呈现一个区域。非可视元素(如Timer)提供一般功能,通常用于操作可视元素。

目前,我们将关注基本的视觉元素,例如Item, Rectangle, Text, Image和MouseArea。但是,通过使用Qt Quick Controls 2模块,可以创建由标准平台组件(如按钮、标签和滑块)构建的用户界面。

项目元素

Item是所有可视元素的基本元素,因为所有其他可视元素都继承自Item。它本身不绘制任何东西,但定义了所有视觉元素共有的所有属性:

  • 几何学 - x和y要定义左上角的位置,width和height用于元素的扩展,以及z对于堆叠顺序,从元素的自然顺序向上或向下提升元素。
  • 布局处理 - anchors(左、右、上、下、垂直和水平居中)使用可选的margins.
  • 按键处理-附上Key和KeyNavigation属性来控制按键处理和focus属性首先启用键处理。
  • 转换 - scale和rotate转换和类属transform的属性列表x,y,z转换,以及一个transformOrigin点。
  • 视觉的 - opacity为了控制透明度,visible要显示/隐藏元素,clip将绘制操作限制在元素边界,以及smooth以增强渲染质量。
  • 状态定义 - states列表属性与支持的状态列表、当前state属性,而transitions列表属性来显示状态变化。

tip

这Item元素通常用作其他元素的容器,类似于差异元素。


矩形元素

Rectangle延伸Item并为其添加填充颜色。此外,它支持由定义的边框border.color和border.width。要创建圆角矩形,可以使用radius。

Rectangle {id: rect1x: 12; y: 12width: 76; height: 96color: "lightsteelblue"
}
Rectangle {id: rect2x: 112; y: 12width: 76; height: 96border.color: "lightsteelblue"border.width: 4radius: 8
}

在这里插入图片描述


有效的颜色值是SVG颜色名称中的颜色(请参见http://www.w3.org/TR/css3-color/#svg-color
(打开新窗口)).您可以用不同的方式在QML中提供颜色,但最常用的方式是RGB字符串(’ #FF4444 ‘)或作为颜色名称(例如’ white ')。

可以使用一些JavaScript创建随机颜色:

color: Qt.rgba( Math.random(), Math.random(), Math.random(), 1 )

除了填充颜色和边框,矩形还支持自定义渐变:

在这里插入图片描述

渐变是由一系列渐变停止点定义的。每个停靠点都有一个位置和一种颜色。位置标记y轴上的位置(0 =顶部,1=底部)。的颜色GradientStop在该位置标记颜色。


文本元素

若要显示文本,可以使用Text元素。它最显著的属性是text类型的属性string。元素根据给定的文本和使用的字体计算其初始宽度和高度。可以使用字体属性组来影响字体(例如font.family, font.pixelSize, …).要改变文本的颜色,只需使用color。

文本可以向两边和中间对齐horizontalAlignment和verticalAlignment属性。要进一步增强文本呈现,可以使用style和styleColor属性,该属性允许您以轮廓、凸起和凹陷模式呈现文本。

对于较长的文本,通常需要定义一个破裂位置像非常…长的文本,这可以通过使用elide。这elide属性允许您将省略位置设置在文本的左侧、右侧或中间。

如果您不希望省略号模式的“…”出现,但仍然希望看到完整的文本,您也可以使用wrapMode属性(仅在显式设置宽度时有效):

图像元素

一个Image元素能够以各种格式显示图像(例如PNG, JPG, GIF, BMP, WEBP).除了source属性提供图像URL,它包含一个fillMode它控制调整大小的行为。

Image {x: 12; y: 12// width: 72// height: 72source: "assets/triangle_red.png"
}
Image {x: 12+64+12; y: 12// width: 72height: 72/2source: "assets/triangle_red.png"fillMode: Image.PreserveAspectCropclip: true
}

在这里插入图片描述
tip

URL可以是带有正斜杠(")的本地路径。/images/home.png”)或网络链接(例如http://example.org/home.png
(打开新窗口)”).

Image元素使用PreserveAspectCrop还应该启用剪辑,以避免图像数据呈现在Image界限。默认情况下,剪裁被禁用(clip: false).您需要启用剪辑(clip: true)将绘画约束到元素的边框。


MouseArea元素

为了与这些元素进行交互,您通常会使用MouseArea。它是一个矩形的不可见项目,你可以在其中捕获鼠标事件。当用户与可视部分交互时,鼠标区域通常与可视项目一起使用来执行命令。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/2176.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

用微服务架构推进企业数字化转型升级

随着数字化转型进入深水区,企业应用程序建设需求急剧增长且变化多端,软件架构经历了单体结构、垂直架构、SOA架构,发展到了现在的微服务架构。 单体架构目前应用较多,部署容易,但单体式应用内部包含了所有需要的服务&…

FPGA——点亮led灯

文章目录 一、实验环境二、实验任务三、实验过程3.1 编写verliog程序3.2 引脚配置 四、仿真4.1 仿真代码4.2仿真结果 五、实验结果六、总结 一、实验环境 quartus18.1 vscode Cyclone IV开发板 二、实验任务 每间隔1S实现led灯的亮灭,实现流水灯的效果。 三、实…

基于卡尔曼滤波进行四旋翼动力学建模(SimulinkMatlab)

💥💥💞💞欢迎来到本博客❤️❤️💥💥 🏆博主优势:🌞🌞🌞博客内容尽量做到思维缜密,逻辑清晰,为了方便读者。 ⛳️座右铭&a…

2.Docker镜像和容器操作

文章目录 Docker操作Docker镜像操作搜索镜像获取镜像镜像加速下载查看镜像详细信息为镜像添加标签删除镜像导出导入镜像上传镜像 Docker容器操作创建容器查看容器状态启动容器创建并启动容器进入容器停止容器删除容器复制容器文件到宿主机容器的导出导入 Docker操作 ###查看do…

vscode 端口转发实现端口映射,实现端口自由

用vscode连接server进行开发, 是非常方便的,但很多时候,server的端口开放的很有限,那么就可以利用vscode进行端口映射 举一个应用场景: 先通过A利用vscode 连接B,然后再vscode 的port窗口进行端口转发&…

SpringBoot中整合Sharding Sphere实现数据加解密/数据脱敏/数据库密文,查询明文

场景 为防止数据泄露,需要在插入等操作时将某表的字段在数据库中加密存储,在需要查询使用时明文显示。 Sharding Sphere ShardingSphere是一套开源的分布式数据库中间件解决方案组成的生态圈, 它由Sharding-JDBC、Sharding-Proxy和Shardi…

如何获取microstore商品详情接口php接口jason数据字段

随着科技的发展,API接口成为了各行业发展的最新趋势。在微店购物平台中,商品详情API接口的引入,为商家和消费者提供了更加便捷、高效的用户体验。本文将为大家详细介绍微店商品详情API接口的优势和使用方法 商品详情API接口的优势 1.提升用户…

【milvus】向量数据库,用来做以图搜图+人脸识别的特征向量

1. 安装milvus ref:https://milvus.io/docs 第一次装东西,要把遇到的问题和成功经验都记录下来。 1.Download the YAML file wget https://github.com/milvus-io/milvus/releases/download/v2.2.11/milvus-standalone-docker-compose.yml -O docker-compose.yml看…

JavaWeb项目【SpringBoot】——图书项目4.0【源码】:SpringBoot版本 springboot相关技术 项目应用

目录 项目简介思考 & 改进1.Jsp都是同步请求---->改成异步Ajax【完成】2.前端用Jsp技术落后----->用Vue框架【完成】3.架构问题:配置数据和Java代码耦合【完成】3.SQL语句和Java代码耦合【完成】4.架构问题:servlet只能处理一个请求5.响应方式…

Web前端工程师笔试题(合集)

Web前端开发工程师笔试题篇1 1. 在一个框架的属性面板中,不能设置下面哪一项。( C ) A.源文件 ; B.边框颜色 ; C.边框宽度 D.滚动条 2. CSS样式表根据所在网页的位置,可分为?(B ) A.行内样式表、内嵌样式表、混合样式表 B.行内样式表、内嵌样式表…

客户案例 | 数字化加速,金融企业实现3D打印式应用程序开发

关键发现: 客户痛点:传统开发周期长,流程复杂,难以满足杭银消金在企业快速发展过程中的应用开发需求;内部业务因为优先级不高,导致开发资源分配有限,更加迟滞了管理部门数字化转型的进度。 解决…

pytorch实现线性回归

转大佬笔记 代码: # -*- coding: utf-8 -*- # Time : 2023-07-14 14:57 # Author : yuer # FileName: exercise05.py # Software: PyCharm import matplotlib.pyplot as plt import torch# x,y是3行1列的矩阵,所以在[]中要分为3个[] x_data torch.…

03 QT对象树

Tips: QT通过对象树机制,能够自动、有效的组织和管理继承自QObject的Qt对象,不需要用户手动回收资源,系统自动调用析构函数。 验证对象树功能: 新建C文件 继承自QPushButton,但没有QPushButton,但有其父类…

谷歌Bard更新:支持中文提问和语音朗读

ChatGPT不断更新功能,从GPT-3到3.5,再到GPT-4,甚至最新的plus版已经支持图像处理和图表生成,而谷歌Bard却自从推出后就一直很安静,没有什么大动作。眼见被ChatGPT、Claude甚至是文心一言抢去了风头,自然心有…

050、事务设计之Percolator事务模型

Percolator 背景 Bigtable: 大表打散每行到各个节点,每一行作为一个kv。解决的问题 一个事务涉及的行在多个节点,如何用单行对一个事务进行控制,实现原子性。 快照隔离级别(snapshot ) 白色点:代表事务开始…

Bring Your Data!Self- supervised Evolution of Large Language Models

Bring Your Data!Self- supervised Evolution of Large Language Models IntroductionMethod参考 Introduction 这篇论文提出了一种自监督的评估方式来衡量大型语言模型的能力和局限性。常规的基于数据集的评估方式存在一些缺点: 需要不断新建数据集。存在数据集和…

不用显示器,不用鼠标和键盘,让我们用主机远程访问OK3588的桌面

不用显示器,不用鼠标和键盘,让我们用主机远程访问OK3588的桌面 MobaXterm软件介绍串口终端运行命令MobaXterm访问开发板 MobaXterm软件介绍 MobaXterm是一款增强型终端软件,对于Windows平台上的程序员、网络管理员和开发者是一款极其优秀的工…

TCP缓冲区和4次挥手调优

目录 如何修改TCP缓冲区才能兼顾并发数量与传输速度? 四次挥手性能调优 1,为什么建立连接是三次握手,而关闭连接需要四次挥手呢? 2.四次挥手的流程,注意5个状态 3.主动方优化 4,被动方调优 最后 如何修改TCP缓冲区才能兼顾并发数量与传输速度&…

【深度学习】目标检测的全面回顾

一、说明 随着自动驾驶汽车、智能视频监控、面部检测和各种人数统计应用的兴起,对快速准确的物体检测系统的需求也在不断增长。这些系统不仅涉及识别和分类图像中的每个对象,还涉及通过在图像周围绘制适当的边界框来定位每个对象。这使得对象检测比其传统…

前端 mock 数据的几种方式

目录 接口demo Better-mock just mock koa webpack Charles 总结 具体需求开发前,后端往往只提供接口文档,对于前端,最简单的方式就是把想要的数据写死在代码里进行开发,但这样的坏处就是和后端联调前还需要再把写死的数据…