Qt Quick - Qt Quick Layouts 布局综述

2023-10-20 00:40
文章标签 布局 qt 综述 quick layouts

本文主要是介绍Qt Quick - Qt Quick Layouts 布局综述,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

Qt Quick Layouts 布局综述

  • 一、概述
  • 二、关键特色
  • 三、简单的布局
    • 1. 大小限制
    • 2. 指定首选大小
  • 四、连接窗口和布局

一、概述

这里记录一下Quick里面的布局控件,Qt Quick Layouts 是一组QML类型,用于在用户界面中布局 item 。与定位器相比,Qt Quick Layouts 还可以调整项目的大小。这使得它们非常适合可缩放的用户界面。由于布局是 Item,因此可以嵌套布局的。Qt Quick Layouts 是用来在用户界面中排列元素的。因为Qt Quick布局也会调整元素的大小,所以非常适合可缩放的用户界面。其实就是和 Qt C++里面的布局类和功能基本是一致的。

这个使用这个模块也是需要引入的,引入下面这个模块就可以了

import QtQuick.Layouts 1.11

二、关键特色

一些关键特性是:

  • 元素的对齐方式可以在布局中指定,通过 Layout.alignment 指定
  • 可以使用布局来指定可缩放项Layout.fillWidthLayout.fillHeight 属性来指定
  • 尺寸约束可以通过布局来指定。Layout.minimumWidth, Layout.preferredWidthLayout.maximumWidth 属性(“Width"可以替换- 为"Height”,用于指定与高度类似的约束)
  • 间距可以通过间距、行间距或列间距指定 spacing, rowSpacing or columnSpacing

除了上述特性,GridLayout还添加了以下特性:

  • 网格坐标可以在布局中指定 Layout.row 和 Layout.column 的属性。
  • 与flow、rows和columns属性一起使用的自动网格坐标 也是支持的。
  • 跨行或跨列的跨度可以使用布局指定。Layout.rowSpan 和 Layout.columnSpan属性。

三、简单的布局

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

import QtQuick 2.14
import QtQuick.Window 2.3
import QtQuick.Layouts 1.3Window {RowLayout {anchors.fill: parentspacing: 6Rectangle {color: 'azure'Layout.preferredWidth: 100Layout.preferredHeight: 150}Rectangle {color: "plum"Layout.fillWidth: trueLayout.fillHeight: true}}}

因为使用布局的目的是在布局改变大小时重新排列其子元素,所以应用程序应该确保布局也调整了大小。在上面的代码片段中,RowLayout 通过指定锚点来确保这一点 anchors.fill: parent。不过,也可以通过其他方式实现,比如直接指定 width 和 height 属性。在同一代码片段中,azure矩形的大小是固定的(100,150)像素,plum矩形将扩展以占据它分配的所有空间。

注意:布局负责它的子元素的几何形状。因此,不应该在这些项上指定width、height、x、y或任何其他可能影响这些属性(如锚点)的属性。否则就会产生布局大小冲突,结果也无法确定。

如果子项是一个布局,情况也是如此。因此,只有没有父布局的布局才能有锚点。anchors.fill: parent。

布局中的所有项目之间将有6像素的间距:

spacing: 6

1. 大小限制

由于元素可以通过其布局调整大小,布局需要知道所有元素的最小、首选和最大尺寸。Layout.fillWidth 或者 Layout.fillHeight设置为true。例如,下面的代码会生成一个布局,其中有两个并排的矩形,它们水平伸展。
在这里插入图片描述

azure矩形的大小可以从50x150调整到300x150, plum矩形的大小可以从100x100调整到∞x100。

import QtQuick 2.14
import QtQuick.Window 2.3
import QtQuick.Layouts 1.3RowLayout {id: layoutanchors.fill: parentspacing: 6Rectangle {color: 'azure'Layout.fillWidth: trueLayout.minimumWidth: 50Layout.preferredWidth: 100Layout.maximumWidth: 300Layout.minimumHeight: 150Text {anchors.centerIn: parenttext: parent.width + 'x' + parent.height}}Rectangle {color: 'plum'Layout.fillWidth: trueLayout.minimumWidth: 100Layout.preferredWidth: 200Layout.preferredHeight: 100Text {anchors.centerIn: parenttext: parent.width + 'x' + parent.height}}}

组合每个item的约束将为布局元素提供以下隐式约束:

minimumpreferredmaximum
隐式约束(宽度)156306∞(Number.POSITIVE_INFINITY)
隐式约束(高度)150150150

因此,在不破坏子项约束的情况下,布局的宽度不能小于156,高度不能小于150。

2. 指定首选大小

对于每个参与布局的Item,有效的首选大小可能来自多个候选属性中的一个。为了确定有效的首选尺寸,它将按照以下顺序查询这些候选属性,并使用第一个具有有效宽度或高度的候选属性。

候选属性描述
Layout.preferredWidth 或 Layout.preferredHeight如果默认的隐式大小没有给出最佳的排列,这些属性应该由应用程序修改。
implicitWidth 或 implicittheight这些属性应该由每个元素提供,以提供有意义的理想尺寸,例如显示文本类型的所有内容所需的尺寸。隐式宽度或高度为0将被解释为无效。
width 和 height如果上述属性都无效,布局将使用width和height属性。

item可以指定 Layout.preferredWidth。而不需要指定 Layout.preferredHeight 在这种情况下,有效的首选高度将从隐式高度(或最终高度)确定。

注意:借助于宽度或高度属性只是作为最后的备用方案。如果要覆盖首选大小,建议使用Layout.preferredWidth 和 Layout.preferredHeight,依赖width或height属性来指定首选尺寸可能会带来一些意想不到的行为。例如,改变宽度或高度属性不会触发布局重排。此外,当布局被迫进行完全重建时,它可能会使用实际的宽度和高度,而不是QML文件中指定的宽度和高度。

四、连接窗口和布局

您可以使用普通的 锚 概念来确保布局将跟随窗口大小调整。 就是用 anchors.fill: parent 来保证布局和窗口粘附一起

RowLayout {id: layoutanchors.fill: parent

布局的大小约束可以用来确保窗口的大小调整不能超过布局约束。你可以从布局中获取尺寸约束,并在窗口元素的minimumWidth、minimumHeight、maximumWidth和maximumHeight上设置这些约束。下面的代码确保窗口的大小调整不会超出布局的限制:

  minimumWidth: layout.Layout.minimumWidthminimumHeight: layout.Layout.minimumHeightmaximumWidth: 1000maximumHeight: layout.Layout.maximumHeight

注意:由于layout.Layout.maximumWidth在本例中是无限的,我们不能将其绑定到Window的maximumWidth属性,因为它是一个整数。因此,我们将最大宽度设置为1000。
最后,你通常希望窗口的初始大小是布局的隐式大小:

  width: layout.implicitWidthheight: layout.implicitHeight

这篇关于Qt Quick - Qt Quick Layouts 布局综述的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/243482

相关文章

HarmonyOS学习(七)——UI(五)常用布局总结

自适应布局 1.1、线性布局(LinearLayout) 通过线性容器Row和Column实现线性布局。Column容器内的子组件按照垂直方向排列,Row组件中的子组件按照水平方向排列。 属性说明space通过space参数设置主轴上子组件的间距,达到各子组件在排列上的等间距效果alignItems设置子组件在交叉轴上的对齐方式,且在各类尺寸屏幕上表现一致,其中交叉轴为垂直时,取值为Vert

嵌入式QT开发:构建高效智能的嵌入式系统

摘要: 本文深入探讨了嵌入式 QT 相关的各个方面。从 QT 框架的基础架构和核心概念出发,详细阐述了其在嵌入式环境中的优势与特点。文中分析了嵌入式 QT 的开发环境搭建过程,包括交叉编译工具链的配置等关键步骤。进一步探讨了嵌入式 QT 的界面设计与开发,涵盖了从基本控件的使用到复杂界面布局的构建。同时也深入研究了信号与槽机制在嵌入式系统中的应用,以及嵌入式 QT 与硬件设备的交互,包括输入输出设

【QT】基础入门学习

文章目录 浅析Qt应用程序的主函数使用qDebug()函数常用快捷键Qt 编码风格信号槽连接模型实现方案 信号和槽的工作机制Qt对象树机制 浅析Qt应用程序的主函数 #include "mywindow.h"#include <QApplication>// 程序的入口int main(int argc, char *argv[]){// argc是命令行参数个数,argv是

lvgl8.3.6 控件垂直布局 label控件在image控件的下方显示

在使用 LVGL 8.3.6 创建一个垂直布局,其中 label 控件位于 image 控件下方,你可以使用 lv_obj_set_flex_flow 来设置布局为垂直,并确保 label 控件在 image 控件后添加。这里是如何步骤性地实现它的一个基本示例: 创建父容器:首先创建一个容器对象,该对象将作为布局的基础。设置容器为垂直布局:使用 lv_obj_set_flex_flow 设置容器

Python QT实现A-star寻路算法

目录 1、界面使用方法 2、注意事项 3、补充说明 用Qt5搭建一个图形化测试寻路算法的测试环境。 1、界面使用方法 设定起点: 鼠标左键双击,设定红色的起点。左键双击设定起点,用红色标记。 设定终点: 鼠标右键双击,设定蓝色的终点。右键双击设定终点,用蓝色标记。 设置障碍点: 鼠标左键或者右键按着不放,拖动可以设置黑色的障碍点。按住左键或右键并拖动,设置一系列黑色障碍点

使用Qt编程QtNetwork无法使用

使用 VS 构建 Qt 项目时 QtNetwork 无法使用的问题 - 摘叶飞镖 - 博客园 (cnblogs.com) 另外,强烈建议在使用QNetworkAccessManager之前看看这篇文章: Qt 之 QNetworkAccessManager踏坑记录-CSDN博客 C++ Qt开发:QNetworkAccessManager网络接口组件 阅读目录 1.1 通用API函数

Qt多语种开发教程

Qt作为跨平台的开发工具,早已应用到各行各业的软件开发中。 今天讲讲,Qt开发的正序怎么做多语言开发。就是说,你设置中文,就中文显示;设置英语就英文显示,设置繁体就繁体显示,设置发育就显示法语等。 开发环境(其实多语种这块根环境没太大关系):win10,Qt.5.12.10 一.先用QtCreator创建一个简单的桌面程序 1.工程就随便命名“LanguageTest”,其他默认。 2.在设计师

Apache Tiles 布局管理器

陈科肇 =========== 1.简介 一个免费的开源模板框架现代Java应用程序。  基于该复合图案它是建立以简化的用户界面的开发。 对于复杂的网站,它仍然最简单,最优雅的方式来一起工作的任何MVC技术。 Tiles允许作者定义页面片段可被组装成在运行一个完整的网页。  这些片段,或Tiles,可以用于为了降低公共页面元素的重复,简单地包括或嵌入在其它瓦片,制定了一系列可重复使用

【CSS in Depth 2 精译_023】第四章概述 + 4.1 Flexbox 布局的基本原理

当前内容所在位置(可进入专栏查看其他译好的章节内容) 第一章 层叠、优先级与继承(已完结) 1.1 层叠1.2 继承1.3 特殊值1.4 简写属性1.5 CSS 渐进式增强技术1.6 本章小结 第二章 相对单位(已完结) 2.1 相对单位的威力2.2 em 与 rem2.3 告别像素思维2.4 视口的相对单位2.5 无单位的数值与行高2.6 自定义属性2.7 本章小结 第三章 文档流与盒模型(已

Qt中window frame的影响

window frame 在创建图形化界面的时候,会创建窗口主体,上面会多出一条,周围多次一圈细边,这就叫window frame窗口框架,这是操作系统自带的。 这个对geometry的一些属性有一定影响,主要体现在Qt坐标系体系: 窗口当中包含一个按钮,这个按钮的坐标系是以父元素为参考,那么这个参考是widget本体作为参考,还是window frame作为参考,这两种参考体系都存在