嵌入式Qt QGridLayout网格布局管理器

一.QGridLayout网格布局管理器

//以行为单位 设置比例系数
void QGridLayout::setRowStretch ( int row, int stretch )

//以列为单位 设置比例系数
void QGridLayout::setColumnStretch ( int column, int stretch )

 

实验:

Widget.h:

#ifndef _WIDGET_H_
#define _WIDGET_H_

#include <QtGui/QWidget>
#include <QPushButton>

class Widget : public QWidget
{
    Q_OBJECT
private:
    QPushButton TestBtn1;
    QPushButton TestBtn2;
    QPushButton TestBtn3;
    QPushButton TestBtn4;

    void initControl();
    void testVBoxLayout();
    void testHBoxLayout();
    void testVHBoxLayout();
    void testQGridLayout();
    void testQGridLayout2();
public:
    Widget(QWidget *parent = 0);
    ~Widget();
};

#endif

 Widget.cpp:

#include "Widget.h"
#include <QVBoxLayout>


Widget::Widget(QWidget *parent) : QWidget(parent),
    TestBtn1(this), TestBtn2(this), TestBtn3(this), TestBtn4(this)
{
    //initControl();
    //testQGridLayout();//QGridLayout 网格布局管理,以网格方式管理用户组件
    //testQGridLayout2();//QGridLayout 网格布局管理 以跨行跨列方式管理用户组件
}

//QGridLayout 以网格方式管理用户组件
 void Widget::testQGridLayout()
 {
    QGridLayout* layout = new QGridLayout;

     TestBtn1.setText("Test Button 1");
     TestBtn1.setSizePolicy(QSizePolicy::Expanding, QSizePolicy::Expanding);
     TestBtn1.setMinimumSize(160, 30);

     TestBtn2.setText("Test Button 2");
     TestBtn2.setSizePolicy(QSizePolicy::Expanding, QSizePolicy::Expanding);
     TestBtn2.setMinimumSize(160, 30);

     TestBtn3.setText("Test Button 3");
     TestBtn3.setSizePolicy(QSizePolicy::Expanding, QSizePolicy::Expanding);
     TestBtn3.setMinimumSize(160, 30);

     TestBtn4.setText("Test Button 4");
     TestBtn4.setSizePolicy(QSizePolicy::Expanding, QSizePolicy::Expanding);
     TestBtn4.setMinimumSize(160, 30);


     layout->setSpacing(30);

     /* addWidget 以坐标形式添加组件到 QGridLayout
     */
     layout->addWidget(&TestBtn1,0,0);
     layout->addWidget(&TestBtn2,0,1);
     layout->addWidget(&TestBtn3,1,0);
     layout->addWidget(&TestBtn4,1,1);

     /*
    设置 第0行 比例因子为1
    设置 第1行 比例因子为3
    */
     layout->setRowStretch(0,1);
     layout->setRowStretch(1,3);
     /*
    设置 第0列 比例因子为1
    设置 第1列 比例因子为3
    */
     layout->setColumnStretch(0,1);
     layout->setColumnStretch(1,3);

     setLayout(layout);
 }

 //QGridLayout 以跨行跨列方式管理用户组件
void Widget::testQGridLayout2()
{
     QGridLayout* layout = new QGridLayout;

     TestBtn1.setText("Test Button 1");
     TestBtn1.setSizePolicy(QSizePolicy::Expanding, QSizePolicy::Expanding);
     TestBtn1.setMinimumSize(160, 30);

     TestBtn2.setText("Test Button 2");
     TestBtn2.setSizePolicy(QSizePolicy::Expanding, QSizePolicy::Expanding);
     TestBtn2.setMinimumSize(160, 30);

     TestBtn3.setText("Test Button 3");
     TestBtn3.setSizePolicy(QSizePolicy::Expanding, QSizePolicy::Expanding);
     TestBtn3.setMinimumSize(160, 30);

     TestBtn4.setText("Test Button 4");
     TestBtn4.setSizePolicy(QSizePolicy::Expanding, QSizePolicy::Expanding);
     TestBtn4.setMinimumSize(160, 30);

     layout->setSpacing(10);

     /* addWidget 以坐标形式添加组件到 QGridLayout
     */
     layout->addWidget(&TestBtn1, 0, 0, 2, 1);//坐标:0.0 大小:两个行单元 一个列单元
     layout->addWidget(&TestBtn2, 0, 1, 2, 1);

     //因为TestBtn1 TestBtn2 都占用两行,所以TestBtn3只能从第三行开始 即坐标:2.0 大小:一个行单元,两个列单元
     layout->addWidget(&TestBtn3, 2, 0, 1, 2);
     layout->addWidget(&TestBtn4, 3, 0, 1, 2);

     setLayout(layout);
}

void Widget::initControl()
{
    TestBtn1.setText("Test Button 1");
    TestBtn1.move(20, 20);
    TestBtn1.resize(160, 30);

    TestBtn2.setText("Test Button 2");
    TestBtn2.move(20, 70);
    TestBtn2.resize(160, 30);

    TestBtn3.setText("Test Button 3");
    TestBtn3.move(20, 120);
    TestBtn3.resize(160, 30);

    TestBtn4.setText("Test Button 4");
    TestBtn4.move(20, 170);
    TestBtn4.resize(160, 30);
}

Widget::~Widget()
{
}

 main.cpp:

#include <QtGui/QApplication>
#include "Widget.h"

int main(int argc, char *argv[])
{
    QApplication a(argc, argv);
    Widget w;
    w.show();
    
    return a.exec();
}

  • 8
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

嵌入式_笔记

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

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

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

打赏作者

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

抵扣说明:

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

余额充值