QT 控件 排版

QVBoxLayout 為垂直一格一格的排版樣式,而 QHBoxLayout 則是水平一格一格的排版樣式,舉例如下

Demo3.h

#ifndef DEMO3_H
#define DEMO3_H
 
#include <QWidget>
 
class QPushButton;
 
class Demo3 : public QWidget {
    Q_OBJECT
 
public:
    Demo3(QWidget *parent = 0);
};
 
#endif


Demo3.cpp

#include <QtGui>
#include "Demo3.h"
 
Demo3::Demo3(QWidget *parent) : QWidget(parent) {
    QPushButton *b1, *b2, *b3, *b4, *b5;
    b1 = new QPushButton(tr("b1"));
    b2 = new QPushButton(tr("b2"));
    b3 = new QPushButton(tr("b3"));
    b4 = new QPushButton(tr("b4"));
    b5 = new QPushButton(tr("b5"));
     
    QHBoxLayout *layout = new QHBoxLayout;
    layout->addWidget(b1);
    layout->addWidget(b2);
    layout->addWidget(b3);
    layout->addWidget(b4);
    layout->addWidget(b5);
     
    setLayout(layout);
    setWindowTitle(tr("Demo3"));
}


main.cpp

#include <QtGui>
#include "Demo3.h"
 
int main(int argv, char **args)
{
    QApplication app(argv, args);
 
    Demo3 demo;
    demo.show();
 
    return app.exec();
}


效果:



其他常見的像是一列兩欄的 QFormLayout ,可供輸入表單之用,舉例如下


Demo4.h

#ifndef DEMO4_H
#define DEMO4_H
 
#include <QWidget>
 
class QPushButton;
class QLineEdit;
 
class Demo4 : public QWidget {
    Q_OBJECT
 
public:
    Demo4(QWidget *parent = 0);
};
 
#endif

Demo4.cpp

#include <QtGui>
#include "Demo4.h"
 
Demo4::Demo4(QWidget *parent) : QWidget(parent) {
    QPushButton *b1, *b2;
    QLineEdit *c1, *c2;
    b1 = new QPushButton(tr("b1"));
    c1 = new QLineEdit;
    b2 = new QPushButton(tr("b2"));
    c2 = new QLineEdit;
     
    QFormLayout *layout = new QFormLayout;
    layout->addRow(b1, c1);
    layout->addRow(b2, c2);
     
    setLayout(layout);
    setWindowTitle(tr("Demo4"));
}

main.cpp

#include <QtGui>
#include "Demo4.h"
 
int main(int argv, char **args)
{
    QApplication app(argv, args);
 
    Demo4 demo;
    demo.show();
 
    return app.exec();
}


 效果:



  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Qt的网格布局(QGridLayout)是一种方便的方式来排列控件。它将控件放置在一个二维的网格中,类似于表格布局。 下面是一个简单的示例,展示如何使用网格布局来排版控件: ```cpp #include <QtWidgets> int main(int argc, char *argv[]) { QApplication app(argc, argv); // 创建一个主窗口 QWidget window; window.setWindowTitle("Grid Layout Example"); // 创建一个网格布局 QGridLayout *layout = new QGridLayout(&window); // 创建一些控件 QLabel *label1 = new QLabel("Label 1"); QLabel *label2 = new QLabel("Label 2"); QPushButton *button1 = new QPushButton("Button 1"); QPushButton *button2 = new QPushButton("Button 2"); // 将控件添加到网格布局中 layout->addWidget(label1, 0, 0); // 在第一行、第一列 layout->addWidget(label2, 0, 1); // 在第一行、第二列 layout->addWidget(button1, 1, 0); // 在第二行、第一列 layout->addWidget(button2, 1, 1); // 在第二行、第二列 // 设置布局边距和控件间距 layout->setContentsMargins(10, 10, 10, 10); layout->setSpacing(10); // 显示主窗口 window.show(); return app.exec(); } ``` 在这个示例中,我们创建了一个主窗口,并在其中创建了一个网格布局。然后,我们创建了两个标签和两个按钮,并将它们添加到网格布局中的不同位置。最后,我们设置了布局的边距和控件间距,并显示了主窗口。 当运行这个示例时,你会看到标签和按钮按照网格布局的方式进行排列。 希望这个示例对你有所帮助!如果你还有其他问题,请随时提问。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值