## 11.2在 Qt Designer 中使用布局
為了確保界面元素在應用程序程序在運行時或被預覽時的各種狀態下都能夠正常顯示,我們需要把它們放進布局當中去。
### 11.2.1 應用和破除布局
應用布局的最簡單做法是選中界面元素,使用工具欄上的按鈕、鼠標右鍵的上下文菜單,以及【Form】菜單都可以實現。
一旦界面元素被放進一個布局之中,它就不能單獨自由行動了 -你不可以單獨改變它的 大小,因為布局接管了這一工作,它控制了位于其中的界面元素的幾何以及間隔器的大小策 略提示(size hint)。所以你要么破除布局,人工調整界面元素的大小,要么通過調整布 局的大小來間接調整界面元素的大小。
要破除一個布局,可以使用快捷鍵 Ctrl+0 或者通過鼠標右鍵上下文菜單以及主菜單項 或工具欄按鈕。在一個布局完成之后,你仍然可以向其中添加或刪除間隔器來影響布局內部 的窗口部件的幾何,最為便捷的方式是從部件選擇器中拖出一個間隔器,并把它拖入到布局 之中,刪除的時候則相反,把間隔器從布局中拖出來即可。
1\. 向布局中增加窗口部件
如圖 11-11 所示,要向一個已經存在的布局中增加窗口部件,只需要選中并拖動該窗口部件,把它從當前位置拖進布局之中,并在認為合適的位置放開鼠標。注意,當你的拖動 窗口部件在布局上方停留時,布局內部會顯示一條藍色的線,它提示了你的窗口部件未來在布局中的位置。

圖 11-11 向布局中增加窗口部件
2\. 設置一個頂級布局(Top Level Layout) 設置界面的頂級布局是很有必要的,它能確保窗口界面元素在應用程序的各種狀態下均能夠保持適當的大小。
要設置頂級布局,需要用鼠標左鍵選中該 Form,然后使用快捷鍵或工具欄或者主菜單 項來選中一種布局。
如何驗證已經設置了頂級布局呢,簡單的做法就是在 Qt Designer 的預覽窗口(按下 Ctrl+R 鍵)中,使用鼠標左鍵拖動窗口的邊緣手柄,查看界面元素的變化情況。如果一切 正常,那就表示你已經設置過了。還有一種做法,就是用鼠標左鍵點擊界面表單(你的 Form),然后在對象查看器中,如果看到 Form 前面有常見的幾種布局圖標之一(圖 11-12 中是垂直布局),那么就表示你已經設置了頂級布局,如圖 11-12 所示;反之,如果 Form 前面的圖標右下角帶有一個紅色的停止標志,就表示還沒有設置頂級布局,如圖 11-13 所 示。

圖 11-12 在對象查看器中瀏覽頂級布局-存在頂級布局

圖 11-13 在對象查看器中瀏覽頂級布局-不存在頂級布局
3\. 應用一個布局
要應用一個布局,你可以使用工具欄上的按鈕,如圖 11-14 所示,也可以使用鼠標右鍵的上下文菜單,如圖 11-15 所示。

圖 11-14 使用工具欄按鈕應用一個布局

圖 11-15 使用鼠標右鍵的上下文菜單來應用一個布局
### 11.2.2 快捷鍵
除了使用標準工具欄以及上下文菜單,我們還可以使用快捷鍵來對布局進行操作。表 11-3 顯示了常見的布局操作所對應的快捷鍵。
表 11-3 布局的快捷鍵
| 布局 | 快捷鍵 | 說明 |
| --- | --- | --- |
| 水平布局 | Ctrl+1 | 將選中的界面元素置于一個水平布局中 |
| 垂直布局 | Ctrl+2 | 將選中的界面元素置于一個垂直布局中 |
| 柵格布局 | Ctrl+5 | 將選中的界面元素置于一個柵格布局中 |
| 表單布局 | Ctrl+6 | 將選中的界面元素置于一個表單布局中 |
| 分裂器水平布局 | Ctrl+3 | 創建一個分裂器水平布局,并將選中的界面元素置于其中 |
| 分裂器垂直布局 | Ctrl+4 | 創建一個分裂器垂直布局,并將選中的界面元素置于其中 |
| 調整大小 | Ctrl+J | 調整布局的大小,以使得位于其中的元素能夠恰當的顯示自身內容。關于這方面的內容,可以參見 QWidget::adjustSize()函數 |
| 破除布局 | Ctrl+0 | 破除選中的布局 |
- 第 1 章 走近 Qt
- 1.1 Qt 簡介
- 1.2 Qt 紀事概覽
- 1.3 Qt 套件的組成(以 Qt4.5 為準)
- 1.4 Qt 的授權
- 1.5 Qt 的產品
- 1.6 Qt 的服務與支持
- 1.7 Qt 的最新進展
- 1.8為什么選擇 Qt
- 1.9 問題與解答
- 1.10 總結與提高
- 第 2 章 Qt 的安裝與配置
- 2.1 獲取 Qt
- 2.2 協議說明
- 2.3 安裝 Qt
- 2.4 配置 Qt4 環境
- 2.5 問題與解答
- 2.6 總結與提高
- 第 3 章 Qt 編程基礎
- 3.1 標準 C++精講
- 3.2 Windows 編程基礎
- 3.3 Linux 編程基礎
- 3.4 Mac 編程基礎
- 3.5 問題與解答
- 3.6 總結與提高
- 第 4 章 Qt 4 集成開發環境
- 4.1 常見的 Qt IDE
- 4.2 Qt Creator
- 4.3 Eclipse
- 4.5 問題與解答
- 4.6 總結與提高
- 第 5 章 使用 Qt 基本 GUI 工具
- 5.1 使用 Qt Designer 進行 GUI 設計
- 5.2 使用 Qt Assistant 獲取在線文檔與幫助
- 5.3 使用 Qt Demo 學習 Qt 應用程序開發
- 5.4 問題與解答
- 5.5 總結與提高
- 第 6 章 Qt 4 程序開發方法和流程
- 6.1 開發方法
- 6.2 Hello Qt
- 6.3 幾個重要的知識點
- 6.4 問題與解答
- 6.5 總結與提高
- 第 7 章 對話框
- 7.1 QDialog 類
- 7.2 子類化 QDialog
- 7.3 快速設計對話框
- 7.4 常見內建(built in)對話框的使用
- 7.5 模態對話框與非模態對話框
- 7.6 問題與解答
- 7.7 總結與提高
- 第 8 章 主窗口
- 8.1 主窗口框架
- 8.2 創建主窗口的方法和流程
- 8.3 代碼創建主窗口
- 8.4 使用 Qt Designer 創建主窗口
- 8.5 中心窗口部件專題
- 8.6 Qt4 資源系統專題
- 8.7 錨接窗口
- 8.8 多文檔
- 8.9 問題與解答
- 8.10 總結與提高
- 第 9 章 Qt 樣式表與應用程序觀感
- 9.1 應用程序的觀感
- 9.2 QStyle 類的使用
- 9.3 樣式表概述
- 9.4 使用樣式表
- 9.5 問題與解答
- 9.6 總結與提高
- 第 10 章 在程序中使用.ui 文件
- 10.1 uic 的使用
- 10.2 Ui_YourFormName.h 文件的組成
- 10.3 編譯時加入處理.ui 文件的方法
- 10.4 運行時加入處理.ui 文件的方法
- 10.5 信號與槽的自動連接
- 10.6 問題與解答
- 10.7 總結與提高 本章主要講解了以下內容:
- 第 11 章 布局管理
- 11.1 基本概念和方法
- 11.2在 Qt Designer 中使用布局
- 11.3 基本布局實踐
- 11.4 堆棧布局
- 11.5 分裂器布局
- 11.6 自定義布局管理器
- 11.7 布局管理經驗總結
- 11.8 問題與解答
- 11.9 總結與提高
- 第 12 章 使用 Qt Creator
- 12.1 Qt Creator 概覽
- 12.2 Qt Creator 的組成
- 12.3 快捷鍵和常用技巧
- 12.4 Qt Creator 構建系統的設置
- 12.5 處理項目間依賴關系( Dependencies )
- 12.6 Qt 多版本共存時的管理
- 12.7 使用定位器在代碼間快速導航
- 12.8 如何創建一個項目
- 12.9 實例講解
- 12.10 使用 Qt Creator 調試程序
- 12.11 問題與解答
- 12.12 總結與提高
- 第 13 章 Qt 核心機制與原理
- 13.1 Qt 對標準 C++的擴展
- 13.2 信號與槽
- 13.3 元對象系統
- 13.4 Qt 的架構
- 13.5 Qt 的事件模型
- 13.6 構建 Qt 應用程序
- 13.7 總結與提高
- 附錄 A qmake 使用指南
- A.1 qmake 簡介
- A.2 使用 qmake
- 附錄 B make 命令
- B.1 命令解釋
- B.2 使用 make 自動構建
- 附錄 C Qt 資源
- C.1Qt 官方資源
- C.2 Qt 開發社區