溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點(diǎn)擊 登錄注冊 即表示同意《億速云用戶服務(wù)條款》

QT之布局管理器(十九)

發(fā)布時(shí)間:2020-09-22 01:54:43 來源:網(wǎng)絡(luò) 閱讀:4679 作者:上帝之子521 欄目:開發(fā)技術(shù)

????????我們在之前的 GUI 開發(fā)中都是使用的是絕對定位,何謂絕對定位呢?就是我們直接在像素級指定各個(gè)組件的位置和大小。比如我們之前使用的 void QWidget::move(int x, int y);void QWidget::resize(int w, int h);這樣存在的問題就是組件的位置和大小無法自適應(yīng)父窗口的變化。

????????我們先來看看絕對定位的代碼和效果是怎樣的?頭文件代碼如下:

#include?<QWidget>
#include?<QPushButton>

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

????void?initControl();
public:
????Widget(QWidget?*parent?=?0);
????~Widget();
};

????????具體函數(shù)代碼如下:

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);
}

??????? 圖一為構(gòu)建運(yùn)行后得到的原始界面,圖二為我們放大后的效果圖:

QT之布局管理器(十九)????????????????????QT之布局管理器(十九)

????????????圖一????????????????????????????????????????????????????????????????????????????????????圖二

????????那么有什么解決方法嗎?答案就是布局管理器,它能夠提供相關(guān)的類對界面組件進(jìn)行布局管理。能夠自動排列窗口中的界面組件,窗口變化后自動更新界面組件的大小。

????????QLayout 是 Qt 中布局管理器的抽象基類,通過繼承 QLayout 實(shí)現(xiàn)了功能各異且互補(bǔ)的布局管理器、Qt 中可以根據(jù)需要自定義布局管理器。注意:布局管理器不是界面部件,而是界面部件的定位策略!?。?/span>

????????關(guān)系如下所示:

QT之布局管理器(十九)


?? ????????QBoxLayout 布局管理器 以水平或者垂直的方式管理界面組件,如下:

?? QT之布局管理器(十九)QT之布局管理器(十九)

????????我們下面來進(jìn)行一組實(shí)驗(yàn),我們先來以垂直的方式進(jìn)行排布,代碼如下:

void?Widget::testVBoxLayout()
{
????QVBoxLayout*?layout?=?new?QVBoxLayout();

????TestBtn1.setText("Test?Button?1");
????TestBtn1.setSizePolicy(QSizePolicy::Expanding,?QSizePolicy::Expanding);?//?設(shè)置水平和垂直方向都隨之變化
????TestBtn1.setMinimumSize(160,?30);???//?設(shè)置最小界面大小

????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(20);?????????//?設(shè)置間距為20個(gè)像素
????layout->addWidget(&TestBtn1);???//?添加?TestBtn1
????layout->addWidget(&TestBtn2);
????layout->addWidget(&TestBtn3);
????layout->addWidget(&TestBtn4);

????setLayout(layout);
}

????????圖三為構(gòu)建運(yùn)行后得到的原始界面,圖四為我們放大后的效果圖:

QT之布局管理器(十九)????????????????????? QT之布局管理器(十九)

????????????????圖三 ????????????????????????????????????????????????????????????????????????????????? 圖四

????????我們再試下水平布局,在上面代碼中僅僅只是將 QVBoxLayout 改成 QHBoxLayout,繼續(xù)構(gòu)建運(yùn)行后效果如下:

QT之布局管理器(十九)

????????那么我們的布局管理器還可以相互嵌套,形成更加復(fù)雜的布局方式。布局嵌套幾乎可以完成所有常用的界面布局,我們還可以定義布局類以達(dá)到個(gè)性化布局的效果。下來我們就做個(gè) QBoxLayout 嵌套示例,如下:

QT之布局管理器(十九)

????????代碼如下:

void?Widget::testVHBoxLayout()
{
????QHBoxLayout*?hLayout1?=?new?QHBoxLayout();??//?設(shè)置水平方向?hLayout1
????QHBoxLayout*?hLayout2?=?new?QHBoxLayout();??//?設(shè)置水平方向?hLayout2
????QVBoxLayout*?vLayout?=?new?QVBoxLayout();???//?設(shè)置垂直方向?vLayout

????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);

????hLayout1->setSpacing(10);???????????//?設(shè)置間距
????hLayout1->addWidget(&TestBtn1);?????//?水平方向添加?TestBtn1
????hLayout1->addWidget(&TestBtn2);?????//?水平方向添加?TestBtn2

????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);

????hLayout2->setSpacing(10);
????hLayout2->addWidget(&TestBtn3);
????hLayout2->addWidget(&TestBtn4);

????vLayout->setSpacing(10);????????????//?設(shè)置間距
????vLayout->addLayout(hLayout1);???????//?豎直方向添加?hLayout1
????vLayout->addLayout(hLayout2);???????//?豎直方向添加?hLayout2

????setLayout(vLayout);
}

????????構(gòu)建運(yùn)行效果如下:

QT之布局管理器(十九)

????????那么本次我們學(xué)習(xí)了布局管理相關(guān)的知識。絕對定位的布局方式是無法適應(yīng)窗口的變化的,在 Qt 中提供了相關(guān)的類對界面組件進(jìn)行布局管理。Qt 預(yù)定義了功能各異的且互補(bǔ)的布局管理器,布局管理器能夠相互嵌套形成復(fù)雜的布局。在后面我們會接著對 Qt 的布局管理方式進(jìn)行學(xué)習(xí)。

向AI問一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI