## 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 显示了样式表的盒子模型。
![](https://box.kancloud.cn/2016-01-22_56a1a15667dba.png)
图 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 开发社区