Qt Quick中控件的定位(qt语音)

网友投稿 392 2022-08-22


Qt Quick中控件的定位(qt语音)

参考文档:​​Quick中也叫锚定位)定位器布局

绝对定位

请看代码

import QtQuickWindow { width: 640 height: 480 visible: true title: qsTr("Hello World") Rectangle { width: 200 height: 200 x: 20 y: 30 color: "green" Rectangle { x: 20 y: 5 width: 150 height: 100 color: "gray" } }}

运行效果

使用x,y定位时,它是相对于父元素的。

也可以通过属性绑定的功能,实现动态布局:

import QtQuickimport QtQuick.ControlsWindow { width: 640 height: 480 visible: true title: qsTr("Hello World") Rectangle { id: rect1 width: 50 height: 60 x: 20 y: 30 color: "green" } Rectangle { x: rect1.x + rect1.width + 5 y: rect1.y + rect1.height + 1 width: 20 height: 20 color: "gray" } Flow { anchors.horizontalCenter: parent.horizontalCenter anchors.bottom: parent.bottom function move(x, y){ rect1.x += x * 5 rect1.y += y * 5 } Button{ text: "+x" onClicked: parent.move(1, 0) } Button{ text: "-x" onClicked: parent.move(-1, 0) } Button{ text: "+y" onClicked: parent.move(0, 1) } Button{ text: "-y" onClicked: parent.move(0, -1) } }}

相对定位(锚定位)

关于锚定位的描述:​​anchors.: itemId.;# 例如:Rectangle { id: rect1; ... }Rectangle { id: rect2; anchors.left: rect1.right; ... }

留白与偏移量 horizontalCenterOff setverticalCenterOffset baselineOffset

第条锚定线都有对应的偏移量

# anchors.Margin/OffsetRectangle { id: rect1; ... }Rectangle { id: rect2; anchors.left: rect1.right; anchors.leftMargin: 5; ... }

只能与兄弟元素和直接父对容器进行锚定

# bad codeItem { id: group1 Rectangle { id: rect1; ... }}Item { id: group2 Rectangle { id: rect2; anchors.left: rect1.right; ... } // invalid anchor!}

定位器

参考文档: ​​​​QtQuickimport QtQuick.ControlsWindow { width: 640 height: 480 visible: true title: qsTr("Positioner") Column { Repeater { model: 10 Rectangle{ height: txt.height width: txt.width color: index % 2 == 0? "skyblue":"gray" Text { id: txt text: qsTr("text" + index) font.pointSize: 24 color: index % 2 == 0? "red":"green" } } } }}

row

import QtQuickimport QtQuick.ControlsWindow { width: 640 height: 480 visible: true title: qsTr("Positioner") Row { Repeater { model: 10 Rectangle{ height: txt.height width: txt.width color: index % 2 == 0? "skyblue":"gray" Text { id: txt text: qsTr("text" + index) font.pointSize: 24 color: index % 2 == 0? "red":"green" } } } }}

超出了范围也不会折行

Flow

import QtQuickimport QtQuick.ControlsWindow { width: 640 height: 480 visible: true title: qsTr("Positioner") Flow { width: Window.width Repeater { model: 10 Rectangle{ height: txt.height width: txt.width color: index % 2 == 0? "skyblue":"gray" Text { id: txt text: qsTr("text" + index) font.pointSize: 24 color: index % 2 == 0? "red":"green" } } } }}

必须要给Flow设置一个宽度,才有换行的功能

Grid

import QtQuickimport QtQuick.ControlsWindow { width: 640 height: 480 visible: true title: qsTr("Positioner") Grid { width: Window.width columns: 3 Repeater { model: 10 Rectangle{ height: txt.height width: txt.width color: index % 2 == 0? "skyblue":"gray" Text { id: txt text: qsTr("text" + index) font.pointSize: 24 color: index % 2 == 0? "red":"green" } } } }}

可以指定行列,一般来说只要指定列即可

LayoutMirroring

import QtQuickimport QtQuick.ControlsWindow { width: 640 height: 480 visible: true title: qsTr("Positioner") LayoutMirroring.enabled: true LayoutMirroring.childrenInherit: true Grid { width: Window.width columns: 3 Repeater { model: 10 Rectangle{ height: txt.height width: txt.width color: index % 2 == 0? "skyblue":"gray" Text { id: txt text: qsTr("text" + index) font.pointSize: 24 color: index % 2 == 0? "red":"green" } } } }}

Positioner

这是一个附加属性,包含的定位器的详细信息

Grid { Repeater { model: 16 Rectangle { id: rect width: 30; height: 30 border.width: 1 color: Positioner.isFirstItem ? "yellow" : "lightsteelblue" Text { text: rect.Positioner.index } } }}

参考文档:​​https://doc.qt.io/qt-6/qml-qtquick-positioner.html​​


版权声明:本文内容由网络用户投稿,版权归原作者所有,本站不拥有其著作权,亦不承担相应法律责任。如果您发现本站中有涉嫌抄袭或描述失实的内容,请联系我们jiasou666@gmail.com 处理,核实后本网站将在24小时内删除侵权内容。

上一篇:JAVA 流程控制专项精讲
下一篇:pip安装报错:No such file or directory 'conda-forge' 没有那个文件或目录 'conda-forge'
相关文章

 发表评论

暂时没有评论,来抢沙发吧~