打开APP
userphoto
未登录

开通VIP,畅享免费电子书等14项超值服

开通VIP
Qt入门-layout布局
userphoto

2015.04.17

关注
分类: [Qt+VS2008]2012-07-19 18:40 11155人阅读 评论(2)  举报
qtlayoutinput图形
开发一个图形界面应用程序,界面的布局影响到界面的美观。在设计一个界面之前,应该考虑到开发的界面可能给不用的用户使用,而用户的屏幕大小、纵横比例、分辨率可能不同,界面还可能是可缩放的,程序应该可以适应这些变化。
前面的程序中都是使用setGeometry()方法定位控件的位置,这个方法比较笨拙。试想如果控件很多,布局这些控件需要编写大量的代码。幸运的是,QT提供了更好的方法布局控件。
常用的三种布局方法:
(1)使用水平布局类QHBoxLayout;
(2)使用垂直布局类QVBoxLayout;
(3)使用网格布局类QGridLayout。
这三种方法可以嵌套使用。
控件在布局时可以先不指定父窗口,最后交由Layout统一指定。
示例:
[cpp] view plaincopy
#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:
[cpp] view plaincopy
//放置一个控件到一个单元格
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
[cpp] view plaincopy
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
[cpp] view plaincopy
void QGridLayout::setSpacing ( int spacing )
设置控件水平和垂直之间的间隔。
示例:
[cpp] view plaincopy
#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();
}
编译运行,界面如图:
本站仅提供存储服务,所有内容均由用户发布,如发现有害或侵权内容,请点击举报
打开APP,阅读全文并永久保存 查看更多类似文章
猜你喜欢
类似文章
【热】打开小程序,算一算2024你的财运
Qt 窗体布局
PyQt5之布局管理
QT的自动滚动区QScrollArea的用法,图文详解
612 VB窗体界面控件的规整排列方法
如何使用ComponenetOne创建桌面布局控件
【Qt设计中常见控件、布局选项和属性详解】
更多类似文章 >>
生活服务
热点新闻
分享 收藏 导长图 关注 下载文章
绑定账号成功
后续可登录账号畅享VIP特权!
如果VIP功能使用有故障,
可点击这里联系客服!

联系客服