常用控件(六)

布局管理器

之前使⽤ Qt 在界⾯上创建的控件, 都是通过 “绝对定位” 的⽅式来设定的.
也就是每个控件所在的位置, 都需要计算坐标, 最终通过 setGeometry 或者 move ⽅式摆放过去.这种设定⽅式其实并不⽅便. 尤其是界⾯如果内容⽐较多, 不好计算. ⽽且⼀个窗⼝⼤⼩往往是可以调整的, 按照绝对定位的⽅式, 也⽆法⾃适应窗⼝⼤⼩.因此 Qt 引⼊ “布局管理器” (Layout) 机制, 来解决上述问题.

垂直布局

使用QVBoxLayout表示垂直的布局管理器;

核心属性:

属性说明
layoutLeftMargin左侧边距
layoutRightMargin右侧边距
layoutTopMargin上⽅边距
layoutBottomMargin下⽅边距
layoutBottomMargin下⽅边距
layoutSpacing相邻元素之间的间距

Layout只用于页面布局,没有提供信号;

eg1: 使用QVBoxLayout管理多个控件,创建一个布局管理器,然后再创建三个按钮,将这三个按钮添加进布局管理器;
在这里插入图片描述

运行结果:
在这里插入图片描述

通过上述代码的方式创建一个布局管理器,只能给Widget设定一个布局管理器,并且布局管理器里面的控件大小会随着窗口大小的变化而变化,但是使用Qt Design在窗口中就可以创建多个布局管理器,并且布局管理器里面的控件大小也不随着窗口大小的变化而变化;

QHBoxLayout

使⽤ QHBoxLayout 表⽰垂直的布局管理器.

核心属性

属性说明
layoutLeftMargin左侧边距
layoutRightMargin右侧边距
layoutTopMargin上⽅边距
layoutBottomMargin下⽅边距
layoutBottomMargin下⽅边距
layoutSpacing相邻元素之间的间距

QHBoxLayout和QVBoxLayout使用是一样的,下面我们来演示QHBoxLayout里面嵌入QVBoxLayout的情况:
eg1: QHBoxLayout里面嵌入QVBoxLayout:
核心代码:
在这里插入图片描述
运行结果:
在这里插入图片描述

QGridLayout

Qt 中还提供了 QGridLayout ⽤来实现⽹格布局的效果. 可以达到 M * N 的这种⽹格的效果.

核心属性:

整体和 QVBoxLayout 以及 QHBoxLayout 相似. 但是设置 spacing 的时候是按照垂直⽔平两个
⽅向来设置的.

属性说明
layoutLeftMargin左侧边距
layoutRightMargin右侧边距
layoutTopMargin上⽅边距
layoutBottomMargin下⽅边距
layoutBottomMargin下⽅边距
layoutHorizontalSpacing相邻元素之间⽔平⽅向的间距
layoutVerticalSpacing相邻元素之间垂直⽅向的间距
layoutRowStretch⾏⽅向的拉伸系数
layoutColumnStretch列⽅向的拉伸系数

eg1: 使用QGridLayout管理元素
核心代码:
在这里插入图片描述
运行结果:
在这里插入图片描述

此处也要注意, 设置⾏和列的时候, 如果设置的是⼀个很⼤的值, 但是这个值和上⼀个值之间并
没有其他的元素, 那么并不会在中间腾出额外的空间.

QFormLayout

Qt 还提供了 QFormLayout , 属于是 QGridLayout 的特殊情况, 专⻔⽤于实现两列表单的布局.
这种表单布局多⽤于让⽤⼾填写信息的场景. 左侧列为提⽰, 右侧列为输⼊框.

eg1: 使用 QFormLayout 创建表单.
在这里插入图片描述
运行结果:
在这里插入图片描述

QSpacerItem

使⽤布局管理器的时候, 可能需要在控件之间, 添加⼀段空⽩. 就可以使⽤ QSpacerItem 来表⽰.
核心属性:

属性说明
width宽度
height⾼度
hData⽔平⽅向的 sizePolicy;QSizePolicy::Ignored : 忽略控件的尺⼨,不对布局产⽣影响。QSizePolicy::Minimum : 控件的最⼩尺⼨为固定值,布局时不会超过该值。QSizePolicy::Maximum : 控件的最⼤尺⼨为固定值,布局时不会⼩于该值。QSizePolicy::Preferred : 控件的理想尺⼨为固定值,布局时会尽量接近该值。 QSizePolicy::Expanding : 控件的尺⼨可以根据空间调整,尽可能占据更多空间。QSizePolicy::Shrinking : 控件的尺⼨可以根据空间调整,尽可能缩⼩以适应空间。
vData垂直⽅向的 sizePolicy选项同上.

上述属性在构造函数设置即可.

eg1: 创建一个水平布局的两个按钮

在这里插入图片描述
我们可以通过在两个按钮直接添加一个QSpacerItem来增加空白:
在这里插入图片描述

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

南猿北者

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

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

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

打赏作者

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

抵扣说明:

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

余额充值