Qt入门-layout布局

        开发一个图形界面应用程序,界面的布局影响到界面的美观。在设计一个界面之前,应该考虑到开发的界面可能给不用的用户使用,而用户的屏幕大小、纵横比例、分辨率可能不同,界面还可能是可缩放的,程序应该可以适应这些变化。

        前面的程序中都是使用setGeometry()方法定位控件的位置,这个方法比较笨拙。试想如果控件很多,布局这些控件需要编写大量的代码。幸运的是,QT提供了更好的方法布局控件。

        常用的三种布局方法:

(1)使用水平布局类QHBoxLayout;

(2)使用垂直布局类QVBoxLayout;

(3)使用网格布局类QGridLayout。

这三种方法可以嵌套使用。

 

控件在布局时可以先不指定父窗口,最后交由Layout统一指定。

 

示例:

#include <QApplication>
#include <QDialog>
#include <QPushButton>
#include <QLineEdit>
#include <QLayout>
#include <QLabel>


int main(int argc, char *argv[])
{
	QApplication a(argc, argv);
	QDialog *mainWindow = new QDialog;

	QHBoxLayout *topLayout = new QHBoxLayout;
	QLabel *lbl = new QLabel(QWidget::tr("&Input:"), mainWindow);
	QLineEdit *lineEdt = new QLineEdit(mainWindow);
	lbl->setBuddy(lineEdt);
	topLayout->addWidget(lbl);
	topLayout->addWidget(lineEdt);

	QHBoxLayout *bomLayout = new QHBoxLayout;
	QPushButton *btn_ok = new QPushButton(QWidget::tr("OK"), mainWindow);\
	btn_ok->setDefault(true);
	QPushButton *btn_cancel = new QPushButton(QWidget::tr("Cancel"), mainWindow);
	bomLayout->addStretch();
	bomLayout->addWidget(btn_ok);
	bomLayout->addStretch();
	bomLayout->addWidget(btn_cancel);
	bomLayout->addStretch();

	QVBoxLayout *mainLayout = new QVBoxLayout;
	mainLayout->addLayout(topLayout);
	mainLayout->addLayout(bomLayout);
	
	mainWindow->setLayout(mainLayout);

	mainWindow->resize(300, 100);
	mainWindow->setWindowTitle(QWidget::tr("Qt Test"));
	mainWindow->show();

	return a.exec();
}


编译运行,界面如下:

 

在界面中,最外部是mainLayout,它的类型是垂直布局类QVBoxLayout。它包含了两个水平布局类QHBoxLayout,分别是topLayout和bomLayout。

 

比起QHBoxLayout和HVBoxLayout, QGridLayout运用更加灵活。

QGridLayout的常用方法

(1)addWidget:

//放置一个控件到一个单元格
void	addWidget ( QWidget * widget, int row, int column, Qt::Alignment alignment = 0 )
//如果放置的控件超出一个单元格,则使用该方法
void	addWidget ( QWidget * widget, int fromRow, int fromColumn, int rowSpan, int columnSpan, Qt::Alignment alignment = 0 )

    1)row:指放置控件的网格行号(行号从0开始);

    2)colum:指放置控件的网格列号(从0开始);

    3)alignment:对齐方式。

    4)fromRow:指放置控件的起始网格行号;

    5)fromColumn:指放置控件的起始网格列号;

    6)rowSpan:指放置控件占多少行;

    7)columnSpan:指放置控件占多少列。


(2)addLayout

void	addLayout ( QLayout * layout, int row, int column, Qt::Alignment alignment = 0 )
void	addLayout ( QLayout * layout, int row, int column, int rowSpan, int columnSpan, Qt::Alignment alignment = 0 )

参数与addWidget类似。

(3)setSpacing

void QGridLayout::setSpacing ( int spacing )

设置控件水平和垂直之间的间隔。

示例:

#include <QApplication>
#include <QDialog>
#include <QPushButton>
#include <QLineEdit>
#include <QLayout>
#include <QLabel>
#include <QTextEdit>


int main(int argc, char *argv[])
{
	QApplication a(argc, argv);
	QDialog *mainWindow = new QDialog;

	QGridLayout *gridLayout = new QGridLayout;
	gridLayout->setColumnStretch(0, 1);
	gridLayout->setColumnStretch(1, 4);
	gridLayout->setColumnStretch(2, 1);
	gridLayout->setColumnStretch(3, 1);
	gridLayout->setColumnStretch(4, 4);

	gridLayout->setMargin(15);
	gridLayout->setColumnMinimumWidth(2, 15);


	QLabel *lbl1 = new QLabel(QWidget::tr("First Name:"));
	QLineEdit *edit1 = new QLineEdit;
	QLabel *lbl2 = new QLabel(QWidget::tr("Last Name:"));
	QLineEdit *edit2 = new QLineEdit;
	QLabel *lbl3 = new QLabel(QWidget::tr("Sex:"));
	QLineEdit *edit3 = new QLineEdit;
	QLabel *lbl4 = new QLabel(QWidget::tr("Birthday:"));
	QLineEdit *edit4 = new QLineEdit;
	QLabel *lbl5 = new QLabel(QWidget::tr("Address:"));
	QTextEdit *textEdt = new QTextEdit;



	gridLayout->addWidget(lbl1, 0, 0);
	gridLayout->addWidget(edit1, 0, 1);
	gridLayout->addWidget(lbl2, 0, 3);
	gridLayout->addWidget(edit2, 0, 4);
	gridLayout->addWidget(lbl3, 1, 0);
	gridLayout->addWidget(edit3, 1, 1);
	gridLayout->addWidget(lbl4, 1, 3);
	gridLayout->addWidget(edit4, 1, 4);
	gridLayout->addWidget(lbl5, 2, 0);
	gridLayout->addWidget(textEdt, 3, 0, 2, 5);
	
	mainWindow->setLayout(gridLayout);

	mainWindow->resize(400, 150);
	mainWindow->setWindowTitle(QWidget::tr("Qt Test"));
	mainWindow->show();

	return a.exec();
}


编译运行,界面如图:

  • 20
    点赞
  • 101
    收藏
    觉得还不错? 一键收藏
  • 5
    评论
### 回答1: Qt中的VerticalLayout布局是一种垂直方向的布局方式,它可以将控件按照从上到下的顺序依次排列。在VerticalLayout布局中,每个控件都会占据一定的高度,并且宽度会自动适应布局的宽度。VerticalLayout布局可以通过添加控件、设置控件的大小和位置等方式来实现。它是Qt中常用的布局方式之一,可以用于创建各种不同的界面布局。 ### 回答2: Qt 中的 QVBoxLayout 是一种垂直布局,可以将子控件以垂直方向排布。 使用 QVBoxLayout,我们可以轻松地将控件垂直排列,并且不需要手动设置位置和大小。只需要将子控件添加到 QVBoxLayout 中,即可实现垂直排布。 在使用 QVBoxLayout 时,我们需要注意以下几点: 1. 可以使用 addWidget() 和 addLayout() 方法向 QVBoxLayout 中添加控件,这些控件会按照添加的顺序依次排列。 2. 可以使用 setSpacing() 方法设置子控件之间的间距,这样可以使布局更加美观。 3. 如果子控件太多,可能会导致布局溢出,此时可以将 QVBoxLayout 嵌套在 QScrollArea 中,使用户可以滚动查看所有子控件。 4. 在使用 QVBoxLayout 时,还需要注意子控件的大小。如果某个子控件的大小发生变化,可能会导致整个布局失衡,此时可以使用 setStretchFactor() 方法来为子控件设置伸展因子,从而保持布局的平衡。 总的来说,VBoxLaout 是一种非常方便实用的垂直布局方式,在设计 GUI 界面时可以大大简化布局操作。 ### 回答3: QT中的Vertical Layout布局(垂直布局)是一种方便的布局方式,可以使您的窗口中的控件沿垂直方向自动排列。它适用于需要排列多个控件的窗口,如窗口表单、选项卡等。该布局管理器可以自动控制插入新控件并自动重新设计大小。 使用Vertical Layout布局管理器时,要将输入控件从顶部开始添加,然后下一个控件将添加到第一个控件下方,以此类推。与水平布局不同,垂直布局的控件高度是相同的,但宽度可以是不同的。通过垂直布局,我们可以使多个控件在不同层次上排列,并调整控件之间的间隔,并使其垂直对齐,达到更好的视觉效果。 使用Qt Designer可以轻松创建Vertical Layout布局,只需从Qt Designer的设计面板中选择Vertical Layout,并将其拖放到界面上。可以在Vertical Layout上添加其他控件,并容易地更改每个控件的选项,如大小、间距、对齐等。此外,QT还提供了其他布局管理器,如水平布局(Horizontal Layout)、网格布局(Grid Layout)和对话框布局(Dialog Layout)等,以满足不同UI设计的需要。 总之,在开发QT应用程序时,Vertical Layout布局是一种非常方便的布局方式,可以帮助我们更快速地设计并开发出优秀的用户界面,以提高用户体验。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 5
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值