中文字幕av专区_日韩电影在线播放_精品国产精品久久一区免费式_av在线免费观看网站

溫馨提示×

溫馨提示×

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

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

QT之布局管理器(十九)

發布時間:2020-09-22 01:54:43 來源:網絡 閱讀:4679 作者:上帝之子521 欄目:開發技術

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

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

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

????????具體函數代碼如下:

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

??????? 圖一為構建運行后得到的原始界面,圖二為我們放大后的效果圖:

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

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

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

????????QLayout 是 Qt 中布局管理器的抽象基類,通過繼承 QLayout 實現了功能各異且互補的布局管理器、Qt 中可以根據需要自定義布局管理器。注意:布局管理器不是界面部件,而是界面部件的定位策略!!!

????????關系如下所示:

QT之布局管理器(十九)


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

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

????????我們下面來進行一組實驗,我們先來以垂直的方式進行排布,代碼如下:

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

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

????setLayout(layout);
}

????????圖三為構建運行后得到的原始界面,圖四為我們放大后的效果圖:

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

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

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

QT之布局管理器(十九)

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

QT之布局管理器(十九)

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

void?Widget::testVHBoxLayout()
{
????QHBoxLayout*?hLayout1?=?new?QHBoxLayout();??//?設置水平方向?hLayout1
????QHBoxLayout*?hLayout2?=?new?QHBoxLayout();??//?設置水平方向?hLayout2
????QVBoxLayout*?vLayout?=?new?QVBoxLayout();???//?設置垂直方向?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);???????????//?設置間距
????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);????????????//?設置間距
????vLayout->addLayout(hLayout1);???????//?豎直方向添加?hLayout1
????vLayout->addLayout(hLayout2);???????//?豎直方向添加?hLayout2

????setLayout(vLayout);
}

????????構建運行效果如下:

QT之布局管理器(十九)

????????那么本次我們學習了布局管理相關的知識。絕對定位的布局方式是無法適應窗口的變化的,在 Qt 中提供了相關的類對界面組件進行布局管理。Qt 預定義了功能各異的且互補的布局管理器,布局管理器能夠相互嵌套形成復雜的布局。在后面我們會接著對 Qt 的布局管理方式進行學習。

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

桂阳县| 建平县| 南江县| 汉川市| 伊春市| 赞皇县| 耒阳市| 永吉县| 比如县| 永安市| 仲巴县| 龙山县| 澄城县| 邵武市| 博湖县| 和林格尔县| 泾阳县| 平塘县| 大理市| 合阳县| 华亭县| 和硕县| 嘉义县| 寻甸| 阿勒泰市| 齐齐哈尔市| 永嘉县| 柘荣县| 隆尧县| 民乐县| 兴业县| 定远县| 襄汾县| 湟中县| 上饶市| 望奎县| 永寿县| 海伦市| 麟游县| 武夷山市| 红原县|