第六章 Qt布局管理器Layout


第六章 Qt布局管理器Layout

大家有沒有發現一個現象,我們放置一個組件,給組件最原始的定位是給出這個控件的坐標和寬高值,這樣Qt就知道這個組件的位置。當用戶改變窗口的大小,組件還靜靜地呆在原來的位置,這有時候顯然不是很科。所以Qt提供一種機制-布局,解決了這個問題。只要把組件放入某一種布局之中,當需要調整大小或位置的時候,Qt就知道該怎樣進行調整。

下面舉一個簡單例子:

 1 #include <QApplication>
 2 #include <QWidget>
 3 #include <QSpinBox>
 4 #include <QSlider>
 5 #include <QHBoxLayout>
 6 
 7 int main(int argc, char *argv[])
 8 {
 9     QApplication a(argc, argv);
10     QWidget w = new QWidget;
11     w.setWindowTitle("Enter your age");
12 
13     QSpinBox *spinBox = new QSpinBox;
14     QSlider *slider = new QSlider(Qt::Horizontal);
15     spinBox->setRange(0, 130);
16     slider->setRange(0, 130);
17 
18     QObject::connect(slider, SIGNAL(valueChanged(int)), spinBox, SLOT(setValue(int)));
19     QObject::connect(spinBox, SIGNAL(valueChanged(int)), slider, SLOT(setValue(int)));
20 
21     spinBox->setValue(35);
22 
23     QHBoxLayout *layout = new QHBoxLayout;
24     layout->addWidget(spinBox);
25     layout->addWidget(slider);
26     w.setLayout(layout);
27 
28     w.show();
29     
30     return a.exec();
31 }

編譯運行結果(直接改變窗體大小,看組件的變化):

Qt一共有5種主要的layout,分別是:

水平布局

垂直布局

使用分裂器水平布局

使用分裂器垂直布局

柵格布局

下面使用Qt Creator的designer對垂直布局進行舉例,其他布局的使用方法類似。

1.在左邊的器件欄里拖入三個PushButton和一個Vertical Layout(垂直布局管理器)到中心面板。如下圖。

2.將這三個按鈕放入垂直布局管理器,效果如下。可以看到按鈕垂直方向排列,並且寬度可以改變,但高度沒有改變。

3.我們將布局管理器整體選中,按下上面工具欄的Break Layout按鈕,便可取消布局管理器。(我們當然也可以先將按鈕移出,再按下Delete鍵將布局管理器刪除。)

4.下面我們改用分裂器部件(QSplitter)。

先將三個按鈕同時選中,再按下上面工具欄的Lay Out Vertically in Splitter(垂直分裂器)。

效果如下圖。可以看到按鈕的大小可以隨之改動。這也就是分裂器和布局管理器的分別。

5.其實布局管理器不但能控制器件的布局,還有個很重要的用途是,它能使器件的大小隨着窗口大小的改變而改變。

我們先在主窗口的中心拖入一個文本編輯器Text Edit。

這時直接運行程序,效果如下。可以看到它的大小和位置不會隨着窗口改變。

下面我們選中主窗口部件,然后在空白處點擊鼠標右鍵,選擇Layout->Lay Out in a Grid,使整個主窗口的中心區處於網格布局管理器中。

 

可以看到,這時文本編輯器已經占據了整個主窗口的中心區。

 

運行一下程序,可以看到無論怎樣拉伸窗口,文本編輯框的大小都會隨之改變。


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM