QLayout简介
QLayout
是由具体类 QBoxLayout
、QGridLayout
、QFormLayout
和 QStackedLayout
继承的抽象基类。
对于 QLayout子类或 QMainWindow的用户,很少需要使用 QLayout 提供的基本功能,例如 setSizeConstraint() 或 setMenuBar()。Qt 布局系统提供了一种简单而强大的方法,可以在控件内自动排列子控件,以确保它们充分利用可用空间。Qt 包含一组布局管理类,用于描述控件在应用程序用户界面中的布局方式。 当控件的可用空间发生变化时,这些布局会自动定位和调整控件的大小,确保它们的排列一致并且用户界面作为一个整体仍然可用。
所有 QWidget
子类都可以使用布局来管理它们的子类。QWidget::setLayout()
函数可以为一个控件布局。 当以这种方式在widget
上设置布局时,它负责以下任务:
- 布置子控件。
- 最高层窗口可感知的默认大小。
- 最高层窗口可感知的最小大小。
- 调整大小的处理。
- 当内容改变的时候自动更新:
- 字体大小、文本或者子控件的其它内容。
- 隐藏或者显示子控件。
- 移除一些子控件。
Qt的布局类
Qt的布局类使用手写的C++代码设计的,所以很容易理解和使用。
使用Qt Designer创建的界面生成的代码也使用了布局类。涉及用户界面开发时,Qt Designer非常有用,因为它避免了编译、链接、运行这样一个循环。
水平、垂直、网格、表单布局
为控件提供良好布局的最简单方法是使用内置布局管理器:QHBoxLayout、QVBoxLayout、QGridLayout和 QFormLayout。这些类从QLayout 继承,而 QLayout又从 QObject(而不是QWidget)派生。他们负责一组控件的几何管理。 要创建更复杂的布局,可以将布局管理器相互嵌套。
QHBoxLayout
:从左到右在水平行中布置控件。
QVBoxLayout
: 在垂直列中从上到下布置控件。
QGridLayout
:在二维网格中布置控件。 控件可以占用多个单元格。
QFormLayout
:把控件按照标签-输入框的形式排列在两列。
使用布局提示
当使用布局的时候,构建子控件的时候不需要指定parent,布局将会自动的指定parent(使用QWidget::setParent()
),使它们成为安装了该布局的界面的子控件。
布局中常用的方法有 addWidget()
和addLayout()
.
我们来代码演示一下实现一个这样的布局:
//在头文件中定义和引用所需
#ifndef DIALOG_H
#define DIALOG_H#include <QDialog>
#include<QLineEdit>
#include<QComboBox>
#include<QTextEdit>
#include<qpushbutton.h>
#include<QLabel>
#include<QGridLayout>class Dialog : public QDialog
{Q_OBJECTpublic:Dialog(QWidget *parent = nullptr);~Dialog();private://左边//网格布局QGridLayoutQGridLayout *layout;QLabel *UserNumber;//员工编号QLineEdit *UserNumberEdit;QLabel *UserName;//员工姓名QLineEdit *UserNameEdit;QLabel *UserSex;//性别QComboBox *UserSexCombox;QLabel *UserDepart;//部门QTextEdit *UserDepartEdit;QLabel *UserAge;//年龄QLineEdit *UserAgeEdit;//右边,网格布局QGridLayoutQHBoxLayout* TopRightLayout;QVBoxLayout* RightLayout;QLabel* MyselfInfo;QTextEdit *myselfInfoTextEdit;//右边底部QPushButton *okbtn,*cancelbtn;QHBoxLayout *buttonLayout;
};
#endif // DIALOG_H
在源文件开始实现:
setWindowTitle("员工信息");//标题//左边控件----实例化UserNumber=new QLabel("员工编号");UserNumberEdit=new QLineEdit;UserName=new QLabel("员工姓名");UserNameEdit=new QLineEdit;UserAge=new QLabel("员工年龄");UserAgeEdit=new QLineEdit;UserSex=new QLabel("员工性别");UserSexCombox=new QComboBox;UserSexCombox->addItem("男");UserSexCombox->addItem("女");UserDepart=new QLabel("员工部门");UserDepartEdit=new QTextEdit;
实例化出这些控件之后我们在网格布局中去添加就好了:
//左边网格布局layout =new QGridLayout();layout->addWidget(UserNumber,0,0);layout->addWidget(UserNumberEdit,0,1);layout->addWidget(UserName,1,0);layout->addWidget(UserNameEdit,1,1);layout->addWidget(UserSex,2,0);layout->addWidget(UserSexCombox,2,1);layout->addWidget(UserAge,3,0);layout->addWidget(UserAgeEdit,3,1);layout->addWidget(UserDepart,4,0);layout->addWidget(UserDepartEdit,4,1);//整体QGridLayout *mlayout=new QGridLayout(this);mlayout->addLayout(layout,0,0);
像这样,我们把剩下的去实例化,去布局就可以了:
//右边shang控件TopRightLayout=new QHBoxLayout();MyselfInfo=new QLabel("个人简历");myselfInfoTextEdit=new QTextEdit;RightLayout=new QVBoxLayout();RightLayout->addLayout(TopRightLayout);RightLayout->addWidget(MyselfInfo);RightLayout->addWidget(myselfInfoTextEdit);//右边下部分okbtn=new QPushButton("确认");cancelbtn=new QPushButton("取消");buttonLayout=new QHBoxLayout();buttonLayout->addStretch();buttonLayout->addWidget(okbtn);buttonLayout->addWidget(cancelbtn);
layout->setColumnStretch(0,1);layout->setColumnStretch(1,3);QGridLayout *mlayout=new QGridLayout(this);mlayout->addLayout(layout,0,0);mlayout->addLayout(RightLayout,0,1);mlayout->addLayout(buttonLayout,1,0,1,2);
这样就大功告成了