## 9.3 樣式表概述
樣式表的出現并不是要取代子類化 QStyle 類的方法。事實上,樣式表在 Qt 的風格之上 起作用(如果使用了樣式表,QWidget::style()返回的 QStyle 為”style sheet”),提供 了比 QPalette(用來設置窗口部件的顏色組合)更為靈活、強大的機制。
### 9.3.1 基本語法
樣式表的語法和 HTML CSS 基本是一致的。Qt 的樣式表對大小寫不敏感,但對類名、對 象名和屬性名大小寫敏感。如下示例設置了所有 QTextEdit 對象背景是黃色的,所有 QPushBox 對象文本為綠色:
```
QTextEdit {background:yellow}
QPushBox {color:green}
```
1\.樣式規則
樣式表包含一系列的規則,一個樣式規則由選擇符和定義組成。選擇符( selector)確 定有哪些窗口部件受規則影響,定義說明了在窗口部件上應用哪些屬性。
例如:
```
QRadioButton {color:red}
```
在這條規則里,QRadioButton 是選擇符,{color:red}是定義。這條規則說明了 QRadioButton 和它的子類應該使用紅色作為前景色。
幾個選擇符可以使用一個定義,使用逗號分隔選擇符。如:
```
QPushButton,QCheckEdit,QComboBox {color:red}
```
定義由一個或多個屬性和值對組成,中間用分號隔開,如:
```
QPushButton { color:red;background-color:white }
```
2\.選擇符類型
Qt 支持所有 CSS2 中所有的選擇符,表 9-1 給出了常用的選擇符。
表 9-1 常用的選擇符
| 選擇符 | 示例 | 可以匹配的窗口部件 |
| --- | --- | --- |
| 通配 | * | 所有窗口部件 |
| 類型 | QLabel | 給定類的實例,包括其子類 |
| 屬性 | QComboBox[editable=”true”] | 所有可以編輯的給定類的實例 |
| 類 | .QCheckBox | 給定類的實例,而不包括其子類 |
| 標識 | QRadioButton#red | 對象名為 red 的給定類的對象 |
| 子孫對象 | QWidget QToolButton | 所有是 QWidget 的子孫對象的 QToolButton 對象 |
| 子對象 | QWidget>QGroupBox | 所有是 QWidget 的直接子對象的 QGroupBox 對象 |
3\.子控件
對于復雜控件,可以訪問它的子控件。如 QCheckBox 上的下拉按鈕,QSpinBox 上的向上 和向下箭頭。如:
```
QComboBox::drop-down { image:url (myarrow.png) }
```
上面的代碼使用了自定義的下拉按鈕圖像。 ::是 CSS3 中的偽元素。
4\.偽狀態
選擇符可以包含偽狀態來表示窗口部件的狀態。偽狀態在選擇符之后,以冒號分隔 ,下面定義了當鼠標在 QPushButton 上懸停時的規則:
```
QPushButton : hover {color : white }
```
5\.沖突解決
當不同的規則應用到相同的屬性時,樣式表就產生了沖突。在這種情況下,特定的規則 比通用的規則優先;偽狀態比沒有偽狀態的優先;如果級別相同,則最后一個規則優先。沖 突解決按照 CSS2 規范進行。
6\.層疊
樣式表可以在 Qapplication 這個級別設置,也可以在父窗口部件,子窗口部件級別設 置。實際應用樣式時,則合并者幾個級別的樣式。當有沖突時,窗口部件自身的樣式優先使 用,接下來是父窗口部件,祖先窗口部件,依次類推。
7\.盒子模型
窗口部件盒子窗口部件支持背景(background)、邊框(border)、邊距(margin)、填襯(padding),圖 9-10 顯示了樣式表的盒子模型。

圖 9-10 Qt 樣式表的盒子模型
這個模型可以指定 4 個影響布局的矩形,從而繪制一個自定義的窗口部件:
(1) contents 矩形位于最里面。它是繪制窗口部件內容(如文字或圖片)的地方。
(2) padding 矩形包圍 contents 矩形。它負責由 padding 屬性指定填充操作。
(3) border 矩形包圍 padding 矩形。它為邊界預留空間。
(4) margin 矩形在最外邊,它包圍 border 矩形,負責任何指定的邊緣空白區域。 對于沒有 padding、border 和 margin 的普通窗口部件,這 4 個矩形重合在一起。
- 第 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 開發社區