【Qt之Quick模块】8. Quick基础、布局管理、布局管理器

1. 前言

Qt Quick编程,提供了多种布局方式。
如,静态布局,可以使用组件的x、y属性进行设置,或者进行绑定。
还可以使用锚anchors进行布局。
此外,还可以使用定位器以及定位管理器为多组件进行布局。
但使用布局管理器和锚会占用内存和实例化时间,若使用x、y、width、height等属性能完成需求,两者相较取其轻,则尽量就不要用布局管理器和锚进行布局了。

2. 定位器

定位器(Positioner)是管理声明式用户界面中项目位置的容器项目。位置定位器的行为方式类似于用于标准Qt小部件的布局管理器,但它们本身也是容器。
当需要按照规律的布局安排许多项目时,位置定位器使得工作更加简单。
Qt Quick布局也可以用于在用户界面中布置Qt Quick项目。它们管理声明式用户界面上项目的位置和大小,非常适合可调整大小的用户界面。
包含一些布局:

布局描述
Column将其子项在垂直方向上进行排列。
Flow将其子项并排放置,必要时进行换行。
Grid以网格形式排列其子项。
LayoutMirroring用于反转布局行为的属性。
Positioner提供附加属性,包含有关项在位置定位器中所在位置的详细信息。
Row将其子项在水平方向上进行排列。

2.1. Column布局

Column布局用于垂直排列项。以下示例使用列项在外部项定义的区域中排列三个矩形项。spacing属性设置各矩形间的间隔。

import QtQuickWindow {width: 640height: 480visible: truetitle: qsTr("Hello World")Item {width: 310; height: 170Column {anchors.horizontalCenter: parent.horizontalCenteranchors.verticalCenter: parent.verticalCenterspacing: 5Rectangle { color: "lightblue"; radius: 10.0width: 300; height: 50Text { anchors.centerIn: parentfont.pointSize: 24; text: "Hello" } }Rectangle { color: "gold"; radius: 10.0width: 300; height: 50Text { anchors.centerIn: parentfont.pointSize: 24; text: "World" } }Rectangle { color: "lightgreen"; radius: 10.0width: 300; height: 50Text { anchors.centerIn: parentfont.pointSize: 24; text: "China" } }}}
}

image.png

2.2. Row布局

Row布局用于水平排列项。以下示例使用行项在由外部彩色矩形定义的区域中排列三个带有圆角的矩形项。spacing属性设置为在矩形项之间包含一小段空间。
要确保父矩形足够大,以便在水平居中的行项周围留有一些空间。

import QtQuickWindow {width: 640height: 480visible: truetitle: qsTr("Hello World")Rectangle {width: 320; height: 110color: "#c0c0c0"Row {anchors.horizontalCenter: parent.horizontalCenteranchors.verticalCenter: parent.verticalCenterspacing: 5Rectangle { width: 100; height: 100; radius: 20.0color: "#024c1c" }Rectangle { width: 100; height: 100; radius: 20.0color: "#42a51c" }Rectangle { width: 100; height: 100; radius: 20.0color: "white" }}}

image.png

2.3. Grid布局

Grid布局用于将项以网格或表格形式放置。以下示例使用网格项将四个矩形项放置在一个2x2的网格中。与其他位置管理器一样,可以使用spacing属性指定项之间的间距。

 import QtQuick 2.0Rectangle {width: 112; height: 112color: "#303030"Grid {anchors.horizontalCenter: parent.horizontalCenteranchors.verticalCenter: parent.verticalCentercolumns: 2spacing: 6Rectangle { color: "#aa6666"; width: 50; height: 50 }Rectangle { color: "#aaaa66"; width: 50; height: 50 }Rectangle { color: "#9999aa"; width: 50; height: 50 }Rectangle { color: "#6666aa"; width: 50; height: 50 }}}

image.png

水平和垂直间距之间没有任何区别,因此任何额外的空间都必须在项本身内添加。
网格中的任何空单元格都必须通过在网格定义的适当位置定义占位符项来创建。

2.4. Flow布局

Flow布局用于在页面上放置像单词一样的项,其中行或列中的项不重叠。
Flow布局以类似于网格项的方式排列项,项沿一个轴(次要轴)排列在一行中,并且以另一个轴(主要轴)沿着彼此放置的项的线排列。流动的方向以及项之间的间距由流和间距属性控制。
以下示例显示包含多个文本子项的Flow布局。这些项以类似于屏幕截图中显示的方式排列。

    Rectangle {color: "lightblue"width: 300; height: 200x : parent.x + 350y : 200Flow {anchors.fill: parentanchors.margins: 4spacing: 10Text { text: "Text"; font.pixelSize: 40 }Text { text: "items"; font.pixelSize: 40 }Text { text: "flowing"; font.pixelSize: 40 }Text { text: "inside"; font.pixelSize: 40 }Text { text: "a"; font.pixelSize: 40 }Text { text: "Flow"; font.pixelSize: 40 }Text { text: "item"; font.pixelSize: 40 }}}

image.png

2.5. Transition使用过渡

以上四个定位器添加或删除一个子项目时,可以使用过渡(Transition),使操作具有动画效果。
四个定位都有add、move、populate属性,在给属性分配一个Transition对象。
add过渡:在定位器创建完毕后,向定位器添加一个子项,或是将子项通过更换父对象的方式变为定位器的子孩子时;
move过渡:在删除定位器中的子项时,或将子项更换父对象从定位器移除时;
populate过渡:定位器第一次创建时,只会运行一次。
此外,将项目的透明度设置为0时,会使用move过渡隐藏项目;当项目的透明度设为非0时,使用add过渡显示项目,定位器过渡只会影响项目的位置(x,y)。

import QtQuickWindow {width: 640height: 480visible: truetitle: qsTr("Hello World")Rectangle {width: 112; height: 112anchors.centerIn: parentcolor: "#303030"Grid {anchors.horizontalCenter: parent.horizontalCenteranchors.verticalCenter: parent.verticalCentercolumns: 2spacing: 6Rectangle { id:aa6666; color: "#aa6666"; width: 50; height: 50 }Rectangle { color: "#aaaa66"; width: 50; height: 50 }Rectangle { color: "#9999aa"; width: 50; height: 50 }Rectangle { color: "#6666aa"; width: 50; height: 50 }move: Transition {NumberAnimation{properties: "x,y"duration: 2000}}focus:trueKeys.onSpacePressed: aa6666.visible = ! aa6666.visible}}
}

当按下空格键时,矩形的visible值会改变,矩形会使用move过渡进行移动
初始化:
image.png
按下:
image.png
结果:
image.png

2.6. Repeater

Repeater类型用来创建大量重复或相似的项目。Repeater包含一个model和一个delegate属性。
delegate属性用来将model中的每个项进行可视化显示,Repeater通常会用于定位器中进行布局。

import QtQuickWindow {width: 640height: 480visible: truetitle: qsTr("Hello World")Grid{columns: 4spacing: 20Repeater{model: 12Rectangle {width: 50; height: 50color: "#aaaa66"}}}
}

设置model为12,列是4列,会自动计算为3行,可以用count属性获取项目数量,该属性为只读。
image.png

2.7. Positioner

Column、Row、Grid、Flow这四个定位器都会附加一个Positioner类型的对象作为顶层子项,Positioner可以提供子项的索引等信息。
如下代码所示:

import QtQuickWindow {width: 640height: 480visible: truetitle: qsTr("Hello World")Grid{columns: 4spacing: 20Repeater{model: 12Rectangle {width: 50; height: 50color: Positioner.isLastItem ?"red" : "#aaaa66"}}}
}

创建12个子项,当是最后一个子项时,设置为red,其他为aaaa66
image.png
#3. 锚anchors布局
除了更传统的Grid、Row和Column之外,Qt Quick还提供了一种使用锚的概念来布局项目的方法。每个项目都有7条不可见的“锚线”:左、水平中心、右、顶、垂直中心、基线和底。
image.png
基线对应于文本所在的想象线。对于没有文本的项目,它与top相同。
Qt快速锚定系统允许定义不同项目的锚线之间的关系。例如,可以这样写:

 Rectangle { id: rect1; ... }Rectangle { id: rect2; anchors.left: rect1.right; ... }

rect2的左边缘绑定到rect1的右边缘,如下:
image.png
或者

 Rectangle { id: rect1; ... }Rectangle { id: rect2; anchors.left: rect1.right; anchors.top: rect1.bottom; ... }

image.png
通过指定多个水平或垂直锚点,可以控制项的大小。下面,rect2锚定在rect1的右侧和rect3的左侧。如果其中一个蓝色矩形被移动,rect2将根据需要拉伸和收缩:

 Rectangle { id: rect1; x: 0; ... }Rectangle { id: rect2; anchors.left: rect1.right; anchors.right: rect3.left; ... }Rectangle { id: rect3; x: 150; ... }

image.png
锚定系统还允许为一个项目的锚指定边距和偏移量。边距指定要留给项目锚点外部的空白量,而偏移量允许使用中心锚线来操纵定位。一个项目可以通过leftMargin、rightMargin、topMargin和bottomMargin分别指定锚边距,或者使用锚。为所有四条边指定相同的边距值。锚点偏移量由horizontalCenterOffset, verticalCenterOffset和baselineOffset指定。
image.png
如:

 Rectangle { id: rect1; ... }Rectangle { id: rect2; anchors.left: rect1.right; anchors.leftMargin: 5; ... }

image.png

4. 布局管理器

Qt Quick布局管理器与定位器不同,布局管理器继承于Item,因此可以嵌套。Qt Quick 布局管理器与传统Qt Widgets 应用中的布局管理器很相似。
使用:

 import QtQuick.Layouts

4.1 特性

布局管理器有一些关键特性。这些特性使得开发者可以更灵活地控制组件(例如按钮、标签等UI元素)在界面上的排列和尺寸。

  1. 对齐方式:通过Layout.alignment属性,开发者可以指定组件的对齐方式。这决定了组件在网格中的位置。
  2. 可调整大小Layout.fillWidthLayout.fillHeight属性允许开发者设置组件的尺寸可以随着容器尺寸的变化而变化,以填充整个行或列。
  3. 尺寸约束Layout.minimumWidthLayout.preferredWidthLayout.maximumWidth属性允许开发者设置组件的最小、首选和最大宽度。这些属性可以用于确保组件不会太小或太大。同样,对于高度,可以将“Width”替换为“Height”。
  4. 间距spacingrowSpacingcolumnSpacing属性允许开发者设置组件之间的间距,行与行之间的间距,以及列与列之间的间距。
  5. 网格坐标:通过Layout.rowLayout.column属性,开发者可以指定组件所在的网格行和列。
  6. 自动网格坐标:结合使用flow, rows, 和 columns属性,GridLayout可以自动确定组件的行和列位置。
  7. 跨行或跨列:通过Layout.rowSpanLayout.columnSpan属性,开发者可以指定组件跨越的行数或列数。这使得组件可以在网格中跨越多个行或列。

4.2 大小

通过布局管理器调整大小,需要指定最小宽高,最佳宽高,最大宽高,如下:

import QtQuick
import QtQuick.LayoutsWindow {width: 640height: 480visible: truetitle: qsTr("Hello World")RowLayout {anchors.fill: parentspacing: 6Rectangle {color: 'blue'Layout.preferredWidth: 100Layout.preferredHeight: 150}Rectangle {color: "plum"Layout.fillWidth: trueLayout.fillHeight: true}}
}

image.png

4.3 stackLayout

StackLayout栈控件可以管理多个项目,但只能显示一个,如下:

import QtQuick
import QtQuick.LayoutsWindow {width: 640height: 480visible: truetitle: qsTr("Hello World")StackLayout {id: layoutanchors.fill: parentcurrentIndex: 1Rectangle {color: 'teal'implicitWidth: 200implicitHeight: 200}Rectangle {color: 'plum'implicitWidth: 300implicitHeight: 200}}MouseArea{anchors.fill: parentonClicked: {if(layout.currentIndex === 1){layout.currentIndex = 0;}else{layout.currentIndex = 1;}}}
}

当点击屏幕时,来回切换视图
image.png

5. 布局镜像

布局镜像属性用来在水平方向上镜像项目的锚布局、定位器和视图等。
LayoutMirroring.enabled: true:默认镜像只影响项目本身;
LayoutMirroring.childrenInherit: true:该项目下的所有子项目都会启用镜像
如下:将Rectangle从右往左显示

import QtQuickRectangle {width: 640height: 480visible: trueLayoutMirroring.enabled: trueLayoutMirroring.childrenInherit: trueRow{anchors{left:parent.left;margins: 5}y:5; spacing: 5; padding: 5Repeater{model: 5Rectangle{color:"red"opacity: (5-index)/5width: 50;height: 50Text {text: index +1anchors.centerIn: parentfont{bold: true}}}}}
}

image.png

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

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

相关文章

AI墨墨交流群正式成立:探索科技前沿,共建智能未来

在这个充满变革的时代,AI技术正如涌泉般迸发,带来无限可能。我们深感,唯有汇聚智慧,方能更好地驾驭这股前沿科技的潮流。因此,我们自豪地宣布:AI墨墨交流群正式成立了!这不仅是一个交流群&#…

【Unity】Timer计时器属性及使用

可以代替协程完成延时操作 可以不用Update进行计时 GitHub开源计时插件 网址:https://github.com/akbiggs/UnityTimer/tree/master 导入:URL:https://github.com/akbiggs/UnityTimer.git 基本功能: 创建计时器: Time…

无法访问Bing网站 - 解决方案

问题 Bing官方网址:https://www.bing.com/ 电脑无法访问Bing网站,但手机等移动设备可以访问Bing网站,此时可尝试以下方案。 以下方案适用于各种系统,如Win/Linux系统。 解决方案 方案1 修改Bing网址为:https://www4…

Windows VSCode 使用Python

一、vscode中安装python 二、下载python.exe(即vscode中需要的python解释器) 下载地址:https://www.python.org/downloads/ 三、安装第三方代码规范工具 参考网址:https://www.python.org/downloads/ 工具介绍 flake8 &#xf…

人工智能在库存管理中的应用

人工智能在库存管理中的应用 目录 人工智能在库存管理中的应用一、什么是库存管理?二、如何利用AI进行智能库存管理?简化整个库存管理流程在仓库中使用基于人工智能的机器人库存管理及配送数据挖掘与处理提供个性化的客户体验 三、利用人工智能改善库存管…

vue知识-04

计算属性computed 注意: 1、计算属性是基于它们的依赖进行缓存的 2、计算属性只有在它的相关依赖发生改变时才会重新求值 3、计算属性就像Python中的property,可以把方法/函数伪装成属性 4、computed: { ... } 5、计算属性必须要有…

为什么大家都在学鸿蒙开发HarmonyOS?

随着HarmonyOS讨论的话题是越来越火热了,大家学习过程中难免也会想这么一个问题,学习HarmonyOS有哪些发展空间?为什么大家都在学鸿蒙开发HarmonyOS? 学习鸿蒙开发OpenHarmony可以满足市场需求,提升技术能力,并参与到…

《华夏教师》是什么级别的期刊?是正规期刊吗?能评职称吗?

《华夏教师》杂志对象主要面向中小学校长和各级教育界管理者,旨在为教育工作者和管理者提供国内外最新、最前沿的教育动态,剖析教育教学热点问题,展现学校教师风采而服务。 收录情况:知网万方维普收录 投稿方式:教育类…

vue3中路由的使用(详细讲解)

1、路由的简介 路由(route):就是根据特定的规则将数据包或请求从源地址传输到目标地址的过程。 在前端或者vue3项目中路由主要用于构建单页面应用程序(SPA),其中所有的页面都在同一个HTML文件中加载,通过JavaScript动…

动态内存管理的题目

数组串联 在leetcode上找的一题 &#xff1a; 给你一个长度为 n 的整数数组 nums 。请你构建一个长度为 2n 的答案数组 ans &#xff0c;数组下标 从 0 开始计数 &#xff0c;对于所有 0 < i < n 的 i &#xff0c;满足下述所有要求&#xff1a; ans[i] nums[i]ans[i…

C++学习笔记——对象的指针

目录 一、对象的指针 二、减少对象的复制开销 三、应用案例 游戏引擎 图像处理库 数据库管理系统 航空航天软件 金融交易系统 四、代码的案例应用 一、对象的指针 是一种常用的技术&#xff0c;用于处理对象的动态分配和管理。使用对象的指针可以实现以下几个方面的功…

Linux C/C++ 显示NIC流量统计信息

NIC流量统计信息是由操作系统维护的。当数据包通过NIC传输时&#xff0c;操作系统会更新相关的计数器。这些计数器记录了数据包的发送和接收数量、字节数等。通过读取这些计数器&#xff0c;我们可以获得关于网络流量的信息。 为什么需要这些信息? 可以使用这些信息来监控网络…