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

news2025/2/3 12:42:10

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

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


在这里插入图片描述

界面效果

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

QML语法

import QtQuick 2.12
import QtQuick.Window 2.12

Window {
    id: root
    visible: true
    width: 640
    height: 480
    title: qsTr("QML学习第二篇")

    //  填充矩形
   Rectangle {
       id: rect1    // id: 为矩形对象指定唯一的标识符。在其他部分引用该矩形时使用。
       x: 12 ; y: 12
       width: 76; height: 96
       // 随机值颜色 矩形填充颜色
       color: Qt.rgba(Math.random(), Math.random(),Math.random(), 1)
       Text {
           text: "矩形1"
       }

       // 隐藏矩形2 在单击矩形1时
       MouseArea {
           id: area
           width: parent.width ; height: parent.height
           onClicked: rect2.visible = !rect2.visible
       }
   }

   // 边框圆角矩形
   Rectangle {
       id: rect2
       x:112; y: 12
       width: 100; height: 96
       // 随机值颜色 矩形边框颜色
       border.color: Qt.rgba(Math.random(), Math.random(),Math.random(), 1)
       // 边框粗细
       border.width: 2
       radius: 8
       Text {
           text: "矩形2"
       }

       Rectangle {
           id: button
           x: rect2.x + 2; y : rect2.y + 10
           width: 50; height: 20
           color: 'lightsteelblue'
           border.color: 'slategrey'
           // 设置当前元素在父元素中居中显示的属性。
           anchors.centerIn: parent

           Text {
               anchors.centerIn: parent
               text: "Start"
           }

           MouseArea {
               // 填充整个父元素的范围
               anchors.fill: parent
               onClicked: {
                   status.text = "Button clicked!"
               }
           }
       }
       Text {
           id :status
           x: button.x ; y:70
           text: "Waiting ..."
           horizontalAlignment: Text.AlignLeft
       }
   }

   // 渐变矩形
   Rectangle {
       id: rect3
       x:12; y: rect1.height + 20
       width: 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 : 100
       width: root.width/2; height: 30
       text: "文本可以向两边和中间对齐horizontalAlignment和verticalAlignment属性。要进一步增强文本呈现,可以使用style和styleColor属性,该属性允许您以轮廓、凸起和凹陷模式呈现文本。"
       color: "#303030"
       font.family: "Ubuntu"
       font.pixelSize: 18
       horizontalAlignment: Text.AlignHCenter
       verticalAlignment: Text.AlignVCenter

       // 这elide属性允许您将省略位置设置在文本的左侧、右侧或中间。
       //elide: Text.ElideMiddle  // 你 ... 好

       // 文本过长自动换行
       wrapMode: Text.WordWrap

       // 红色 凹陷的 文本样式
       style: Text.Sunken
       styleColor: '#FF4444'
   }

   // 图像元素
   Image {
       id: pic1
       x: 12; y: rect1.height + rect3.height + 30
       source: "pic//search.png"
       sourceSize: Qt.size(40,40)
       // fillMode: 图像的填充模式。这里设置为Image.PreserveAspectCrop,表示在保持图像长宽比的情况下,缩放图像并裁剪以填充图像元素的大小。
       fillMode: Image.PreserveAspectCrop
       // clip: 是否对图像进行裁剪。这里设置为true,表示在图像元素的边界之外的部分将被裁剪掉。
       clip: true
   }

  Rectangle {
    id: bt
    x: 12; y: rect1.height + rect3.height + pic1.height + 50
    width: 116; height: 50
    color: "lightsteelblue"
    border.color: "slategrey"

    /* property alias text: label.text:这行代码为root矩形定义了一个公开的text属性,通过alias关键字将其与内部的label.text属性进行了绑定。这允许在外部可以直接访问和修改root矩形的文本内容 */
    property alias text: label.text

    Text {
        id: label
        anchors.centerIn: parent
        text: "开始"
    }

    // 鼠标范围信号
    MouseArea {
        anchors.fill: parent
        onClicked: {
            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: rect1
    x: 12; y: 12
    width: 76; height: 96
    color: "lightsteelblue"
}
Rectangle {
    id: rect2
    x: 112; y: 12
    width: 76; height: 96
    border.color: "lightsteelblue"
    border.width: 4
    radius: 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: 72
    source: "assets/triangle_red.png"
}
Image {
    x: 12+64+12; y: 12
    // width: 72
    height: 72/2
    source: "assets/triangle_red.png"
    fillMode: Image.PreserveAspectCrop
    clip: true
}

在这里插入图片描述
tip

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

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


MouseArea元素

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

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

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

相关文章

【题解】 模拟赛2 题解

T1 假设商品价格为x 618:int(x*0.66) 211:x-(x/100)*35 两者比较一下大小即可 #include<bits/stdc.h> using namespace std;int x,x1,x2;int main(){scanf("%d",&x);x1 x*0.66;x2 x-(x/100)*35;if (x1 x2) printf("both\n%d",x1);if (x1 &g…

浏览器打开PDF标题乱码

问题 使用 itext5 用pdf模板生成预览pdf乱码问题 解决办法 使用pdf编辑器打开之后&#xff0c;选择 文件>> 属性&#xff0c; 修改乱码的标题。

【业务功能篇45】SSM整合shiro项目:web.xml执行顺序

web.xml 的加载顺序是&#xff1a;ServletContext -> context-param -> listener -> filter -> servlet 学习shiro时&#xff0c;需要配置shiro &#xff0c;我们需要在filter过滤器之前&#xff0c;先初始化好shiro组件&#xff0c;不然请求认证无法走到shiro,根据…

plt.text()函数解析

plt.text(x, y, s, fontsize, verticalalignment,horizontalalignment,rotation , *kwargs) 参数&#xff1a; x,y:表示坐标值上的值s:表示说明文字fontsize:表示字体大小verticalalignment&#xff1a;垂直对齐方式 &#xff0c;参数&#xff1a;[ ‘center’ | ‘top’ | ‘…

【公益】Q学友联合东湖街道开展“星级大厨来做客”技能培训活动

“大家一定要用温水和面&#xff0c;和面时要注意方向和力度&#xff0c;往同一个方向揉面……”在东湖街道综合文体服务中心一楼的中式面点培训现场&#xff0c;飘荡着阵阵面香&#xff0c;充斥着欢声笑语。 为进一步丰富居民业余文化生活&#xff0c;提高灵活就业人员的职业技…

手把手教你搭建SpringCloud项目:什么是微服务?一看就会系列!

什么是微服务&#xff1f;一看就会系列&#xff01; 一、手把手教你搭建SpringCloud项目&#xff08;一&#xff09;图文详解&#xff0c;傻瓜式操作 二、手把手教你搭建SpringCloud项目&#xff08;二&#xff09;生产者与消费者 三、手把手教你搭建SpringCloud项目&#x…

mpVue 微信小程序基于vant-weapp 组件的二次封装TForm 表单组件(修改源码插槽使用)

一、前言 1、mpVue微信小程序不支持动态组件&#xff08;<component> &#xff09; 2、mpVue微信小程序不支持动态属性及事件穿透&#xff08;$attrs和$listeners&#xff09; 3、mpVue微信小程序不支持render函数 二、最终效果 三、配置参数&#xff08;Attributes&…

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

文章目录 效果QML代码ClickableImage.qml文件Image&#xff08;图片&#xff09;元素 解释 MyQML.qml文件 解释&#xff1a;Window元素、Item元素、Image元素、MouseArea元素、Column元素、Row元素、Grid元素、Flow元、Repeater元素 效果 QML代码 ClickableImage.qml文件 图像…

[JavaScript] 第三章 Chrome 浏览器中执行 JavaScript

系列文章目录 [JavaScript] 第一章 暂无 [JavaScript] 第一章 暂无 [JavaScript] 第三章 Chrome 浏览器中执行 JavaScript 文章目录 系列文章目录前言1、准备工作1.1、创建html工程1.2、创建html文件夹&#xff0c;存放html文件1.3、创建JavaScript演示html1.4、通过idea打开页…

Unity打包窗口化放大、缩小、拖拽功能、无边框设置 C#

Unity打包Windows窗口实现放大、缩小、拖拽、无边框 文章目录 Unity打包Windows窗口实现放大、缩小、拖拽、无边框前言一、引入 user32.dll二、使用步骤1.引入库2.功能封装3.效果图如下&#xff0c;绑定自定义按钮 总结 前言 Unity无边框设置、窗口化放大、缩小、拖拽 提示&am…

蓝牙耳机选购攻略:开放式耳机篇!如何选购开放式耳机?开放式蓝牙耳机哪些品牌比较好?过来人告诉你如何选购开放式耳机!

作为一个耳机爱好者&#xff0c;最近更是喜欢上了开放式蓝牙耳机&#xff0c;实际用过的起码有十几款&#xff0c;但其实最终能留下来的也只有四五款。由于前期并不知道应该如何选择开放式耳机&#xff0c;经常都会高价买到些质量差、音质也不好、漏音大的开放式耳机&#xff0…

DKN和KGC阅读

1. DKN 作者将外部知识图包含的知识融入新闻嵌入。 &#xff08;1&#xff09;将新闻标题单词词嵌入&#xff0c;单词链接的实体嵌入&#xff0c;以及实体的上下文嵌入(邻居实体嵌入的平均)建模为CNN输入的三个通道。 &#xff08;2&#xff09;然后使用KCNN模型&#xff0c…

排序【数据结构】

1、排序的概念 排序&#xff1a; 所谓排序&#xff0c;就是使一串记录&#xff0c;按照其中的某个或某些关键字的大小&#xff0c;递增或递减的排列起来的操作。稳定性&#xff1a; 假定在待排序的记录序列中&#xff0c;存在多个具有相同的关键字的记录&#xff0c;若经过排序…

一个月学通Python(十九):Cookie和Session是什么(Web开发)

专栏介绍 结合自身经验和内部资料总结的Python教程&#xff0c;每天3章&#xff0c;1个月就能全方位的完成Python的学习并进行实战开发&#xff0c;学完了定能成为大佬&#xff01;加油吧&#xff01;卷起来&#xff01; 全部文章请访问专栏&#xff1a;《Python全栈教程&…

C++:这门语言优势在哪?命名空间以及缺省参数?

文章目录 C的优势解决命名空间的问题 缺省参数 C的优势 C和C语言比起来有许多优势&#xff0c;这里我们先举一个例子&#xff0c;后续进行补充 解决命名空间的问题 首先看这样的代码&#xff1a; #include <stdlib.h> #include <stdio.h>int rand 0;int main(…

k8s服务发现之第二弹Service详解

创建 Service Kubernetes Servies 是一个 RESTFul 接口对象&#xff0c;可通过 yaml 文件创建。 例如&#xff0c;假设您有一组 Pod&#xff1a; 每个 Pod 都监听 9376 TCP 端口每个 Pod 都有标签 appMyApp apiVersion: v1 kind: Service metadata:name: my-service spec:s…

创建users子应用

1.创建&#xff1a;(venv) xxxx>python manage.py startapp users 2.移动到apps里面&#xff1b; 3.在settings里面注册子应用&#xff1b; # 注册子应用 apps/users apps/users/apps name apps.users 这个路径是什么就写什么 INSTALLED_APPS [ # 用[../namage.py st…

架构训练营学习笔记:4-3存储架构模式之分片架构和分区架构

分片架构的本质&#xff1a; 分片架构能提升写性能和存储性能&#xff0c;对应的主备架构的本质是备份&#xff0c;主从架构本质提升读性能。 分片架构的两个关键点&#xff1a;分片规则跟路由规则 分片规则&#xff1a; 选择基数比较大的某个数据键值&#xff0c;让数据均匀…

第七章 集成学习

文章目录 第七章 集成学习7.1个体和集成7.2Boosting和AdaBoost7.3Bagging和随机森林7.3.1Bagging7.3.2随机森林 7.4结合策略7.4.1平均法7.4.2投票法7.4.3学习法 7.6实验&#xff1a;Adaboost 第七章 集成学习 7.1个体和集成 集成学习通过构建并结合多个学习器来完成学习任务&…

TS报错Cannot find module ‘xxx‘ or its corresponding type declarations

最近使用 vite vue3 ts 开发一个文本标注的 web 平台&#xff0c;在项目中使用了一个 js-mark 的 npm 包&#xff0c;但是在 import 导入后出现了 TS 报错&#xff1a;TS2307: Cannot find module js-mark or its corresponding type declarations.、无法解析模块 js-mark 的…