qml保姆级教程一:布局组件

💂 个人主页:pp不会算法v
🤟 版权: 本文由【pp不会算法v】原创、在CSDN首发、需要转载请联系博主
💬 如果文章对你有帮助、欢迎关注、点赞、收藏(一键三连)和订阅专栏哦

QML系列教程

QML教程一:布局组件

锚布局anchors

属性介绍

anchors.top : AnchorLine

设置锚布局的顶部的位置
在这里插入图片描述

anchors.bottom :AnchorLine

设置锚布局的底部的位置
在这里插入图片描述

anchors.left : AnchorLine

设置锚布局的左边框的位置
在这里插入图片描述

anchors.right : AnchorLine

设置锚布局的右边框的位置
在这里插入图片描述

anchors.horizontalCenter : AnchorLine

设置锚布局的水平中心线
在这里插入图片描述

anchors.verticalCenter : AnchorLine

设置锚布局的竖直中心线
在这里插入图片描述

anchors.baseline : AnchorLine

baseline就是控件或者窗口的最上方的基准线也就是上边框

在这里插入图片描述

anchors.fill : Item

将这个控件的大小和位置设置为和指定控件的大小和位置完全相等
在这里插入图片描述

anchors.centerIn : Item

将要锚布局设置为item的中央
在这里插入图片描述

anchors.margins : real

锚布局的边距

anchors.topMargin : real

锚布局的上边距
在这里插入图片描述

anchors.bottomMargin : real

锚布局的下边距

anchors.leftMargin : real

锚布局的左边距

anchors.rightMargin : real

锚布局的右边距

anchors.horizontalCenterOffset : real

锚布局水平方向中心线的偏移量,正数表示向右偏移,负数表示向左偏移在这里插入图片描述

anchors.verticalCenterOffset : real

锚布局竖直方向中心线的偏移量,正数表示向下偏移,负数表示向上偏移

anchors.baselineOffset : real

在这里插入图片描述

anchors.alignWhenCentered : bool

在对齐的时候其他锚点位置是否不变,默认值为false,,alignWhenCentered属性仅在使用anchors.centerIn或anchors.fill: parent进行居中对齐时才起作用。如果没有应用这些属性,alignWhenCentered将不会生效。

垂直布局Column

在这里插入图片描述

属性

padding : real

垂直布局和锚布局的间距 值为实数 默认为0
在这里插入图片描述

spacing : real

垂直布局中项与项之间的距离 值为实数 默认为0
在这里插入图片描述

topPadding : real

垂直布局中第一项顶部和所在锚布局的上边框的距离 值为实数 默认为0
在这里插入图片描述

bottomPadding : real

垂直布局中最后一项底部和所在锚布局的上边框的距离 值为实数 默认为0

leftPadding : real

垂直布局中所有项顶部和所在锚布局的左边框的距离 值为实数 默认为0

rightPadding : real

垂直布局中所有项顶部和所在锚布局的左右边框的距离 值为实数 默认为0

populate : Transition

Column布局首次生成的时候其中的项的动画效果
例如下面这个就是生成的时候项的透明度从0变为1,时长为1000毫秒
在这里插入图片描述

add : Transition

添加项的时候的动画效果
例如下面我为添加项时添加了一个从右滑到左的效果

在这里插入图片描述

move : Transition

移动项的时候的动画效果
例如下面我为移动项的时候添加了一个弹动的效果
在这里插入图片描述

水平布局

属性

add : Transition
bottomPadding : real
leftPadding : real
move : Transition
padding : real
populate : Transition
rightPadding : real
spacing : real
topPadding : real

上面这几个属性和垂直布局一样就不再赘述了

layoutDirection : enumeration

布局的排列方向 ,有两个取值从左到右
Qt.LeftToRight,从右到左Qt.RightToLeft,默认值是从左到右

默认效果:
在这里插入图片描述
设置为从右到左的效果:
在这里插入图片描述

effectiveLayoutDirection : enumeration

这是一个只读属性,表示实际的布局方向,收到layoutDirection属性的影响,是由 QML 引擎根据子项和布局的方向等因素计算出来的

信号和槽

positioningComplete()&onPositioningComplete()

该信号在布局完成时发出。
相应的处理程序是onPositioningComplete。
该信号在Qt 5.9中引入。
在这里插入图片描述
从上图发现布局初始化的时候会发出positionComplete这个信号
而且当改动布局完成的时候也会触发该信号

函数

forceLayout()

Row通常每帧定位其子对象一次。这意味着在脚本块内部,底层子级可能已经更改,但Row尚未相应更新。
此方法强制Row立即对其子级中任何未完成的更改作出响应。

简而言之就是强制刷新

网格布局GridLayout

属性

columns : int

列数

rows : int

行数

rowSpacing : real

行与行之间的间隔

columnSpacing : real

列与列之间的间隔

flow : enumeration

此属性保存未设置显式单元格位置的项的流向。它与columns或rows属性一起使用,它们分别指定何时将流重置为下一行或下一列;
可能取值右两个: GridLayout.LeftToRight ,GridLayout.TopToBottom

layoutDirection : enumeration

布局的方向这个和水平布局Row的layoutDirection一样

属性综合演示

在这里插入图片描述

在这里插入图片描述

流式布局Flow

属性

add : Transition
bottomPadding : real
effectiveLayoutDirection : enumeration
flow : enumeration
layoutDirection : enumeration
leftPadding : real
move : Transition
padding : real
populate : Transition
rightPadding : real
spacing : real
topPadding : real
这些属性上面都讲了的

  Flow {
          anchors.fill: parent
          anchors.margins: 4
          spacing: 10

          Text { 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 }
      }

在这里插入图片描述

信号和槽

positioningComplete()&onPositioningComplete()

同上

函数

forceLayout

同上

布局管理器

属性

alignment : Qt.Alignment
可能取值如下:
Qt::AlignLeft
Qt::AlignHCenter
Qt::AlignRight
Qt::AlignTop
Qt::AlignVCenter
Qt::AlignBottom
Qt::AlignBaseline

不冲突的取值可以用 '|'分割一起作为属性值

默认值:Qt.AlignVCenter | Qt.AlignLeft


bottomMargin : real 下边距

column : int 列
columnSpan : int 列宽
row : int 行
rowSpan : int 行框
fillHeight : bool 填充高度
fillWidth : bool 填充宽度
leftMargin : real 左边距
rightMargin : real 右边距
topMargin : real 上边距
margins : real 边距
maximumHeight : real 最大高度
maximumWidth : real 最大宽度
minimumHeight : real 最小高度
minimumWidth : real 最小狂赌
preferredHeight : real 首选高度
preferredWidth : real 首选宽度

  • 0
    点赞
  • 15
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
### 回答1: 在QML中,我们可以使用ListView实现窗口跳转功能。下面是一种常见的实现方式: 首先,我们需要一个存储窗口信息的模型。可以使用一个自定义的数据模型来实现,也可以使用Qt提供的ListModel。 接下来,我们在QML中创建一个ListView,并将该模型设置为其model属性。ListView会根据模型的内容自动生成相应的窗口。 在ListView的delegate属性中,我们可以定义窗口的外观和交互方式。可以使用Rectangle或Item作为窗口的外观,根据需要进行定制。 在窗口外观的交互部分,我们可以添加一个MouseArea来接收鼠标点击事件。在该事件的处理函数中,我们可以获取点击的索引值,并根据需求执行相应的窗口跳转操作。 对于窗口跳转操作,有多种方式可供选择。例如,我们可以使用StackView或StackWindow来进行窗口切换。也可以直接更改显示内容的属性值,实现窗口内容的动态刷新。 在实际开发中,还可以根据具体需求进行更多的定制。例如,可以添加动画效果、设置窗口间的传参、处理窗口关闭等。 总之,使用ListView实现窗口跳转功能的基本步骤包括:创建一个存储窗口信息的模型、将其设置为ListView的model属性、在delegate中定义窗口的外观和交互方式、处理窗口的跳转操作。通过这种方式,我们可以方便地实现在QML中的窗口跳转。 ### 回答2: 在QML中,要实现ListView的窗口跳转,可以通过以下步骤来实现: 1. 创建至少两个QML文件,分别表示不同的窗口。例如,我们可以创建一个名为"MainPage.qml"的主页面和一个名为"DetailPage.qml"的详细页面。 2. 在"MainPage.qml"中创建一个ListView,并设置model为一个代表数据源的ListModel,例如: ListView { model: myModel delegate: Item { // 设置列表项的外观 } } 3. 在"MainPage.qml"中,为ListView的每个列表项添加一个点击事件处理函数,当点击某个列表项时,触发该事件。在该事件处理函数中,可以执行窗口跳转的逻辑,例如: ListView { //... delegate: Item { //... MouseArea { //... onClicked: { // 执行窗口跳转逻辑,例如: var component = Qt.createComponent("DetailPage.qml"); if (component.status === Component.Ready) { var detailPage = component.createObject(parent); // parent为当前页面的父项 // 可以传递数据给DetailPage.qml,例如: detailPage.itemData = model.get(index); } } } } } 4. 在"DetailPage.qml"中,根据需求设计详细页面的布局和内容。 通过以上步骤,当在"MainPage.qml"的ListView中点击某个列表项时,会触发相应的事件处理函数,在该函数中创建并显示"DetailPage.qml"的实例,并根据需要进行数据传递。这样就实现了QML中ListView的窗口跳转。 ### 回答3: QML 中的 ListView 是一个用于显示一个可滚动的列表的控件,它可以用于在窗口中展示一组数据。要实现窗口跳转,可以通过以下步骤: 1. 首先,确保在 QML 中引入 QtQuick 模块,以便使用 ListView 组件: ```qml import QtQuick 2.0 ``` 2. 创建一个 ListView 组件并指定其属性,比如宽度、高度、布局方向等等。 ```qml ListView { width: 200 height: 300 orientation: ListView.Vertical // 设置布局方向为垂直 model: ListModel { ... } // 设置列表的数据 } ``` 3. 在 ListView 的 model 属性中,通过 ListModel 创建一个数据模型,定义列表的内容。可以使用自定义的对象或者简单的字符串等。 ```qml model: ListModel { ListElement { text: "Item 1" } // 第一个列表项 ListElement { text: "Item 2" } // 第二个列表项 // ... } ``` 4. 在 ListView 的 delegate 属性中,定义每个列表项的外观。可以使用自定义的组件或者内置的 Item 组件。 ```qml delegate: Item { width: parent.width height: 50 Rectangle { width: parent.width height: parent.height color: index % 2 === 0 ? "lightgray" : "white" // 每隔一个变换背景色 Text { anchors.centerIn: parent text: model.text // 显示列表项的文本 } MouseArea { anchors.fill: parent onClicked: { // 在此处进行窗口跳转操作,比如使用 StackView 或改变当前窗口的 visible 属性等 } } } } ``` 5. 在 MouseArea 的 onClicked 信号中编写窗口跳转的代码。具体的实现方式取决于你使用的窗口管理器或导航机制。 以上就是利用 QML 中的 ListView 组件实现窗口跳转的基本步骤。根据具体的需求,你可能需要进一步扩展和优化代码。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

pp不会算法^v^

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值