一篇文章 学会Qt 样式表(qss)

QML 中风格和主题的设计可以通过配置文件选择现有几种中的一种,或者直接在控件定义时,指定其属性,如背景颜色或者字体大小。在QWidget框架中,则通过了一种叫做qss样式表的东西来进行描述,跟CSS逻辑上类似。

这个qss抽象出来就两个元素,一个叫做选择器 ,一个叫做属性。简单的说就是谁长什么样子。那这个谁,有好多种写法,比如所有按钮,某个按钮,按下的按钮。而这个样子又有好多,比如背景色,边框,圆角等。

一,实现

1,新建一个qss文件,并添加到资源里。然后在main函数中,进行全局的设置。

2,字体 一般是一个全局的设置,所以可以在此处设置全局字体。微软雅黑 是一个常用的字体

3,我们以如下的窗口来举例说明。

原始窗口如下:

qss 如下:

复制代码
//所有QPushButton 背景色为蓝色,宽高为 180 80
QPushButton{
    background-color: rgb(0, 0, 255);
    width:180px;
    height:80px;
}

//所有QPushButton 鼠标hover时 背景为黄色
QPushButton:hover {
    background-color: rgb(255, 255, 0);
}

//所有QPushButton  flat属性为true 时 背景为绿色
QPushButton[flat="true"] {
    background-color: rgb(0, 255, 0);
}

//指定这两个按钮 背景为红色
#pushButton_5,#pushButton_6{
    background-color: rgb(255, 0, 0);
}

效果如下:

QWidget qss -- Qt hello

4,还可以用自己的图片 替换子控件。

复制代码
/*combobox 的下拉箭头*/
QComboBox::down-arrow {
    image: url(:/img/axis_return.png);
}

二,常用属性

三,QSS支持的类型、属性、伪状态、子控件

Qt Style Sheets Reference | Qt Widgets 5.15.16

四,总结

QWidget qss -- Qt hello

五,qt帮助查询

1、"Qt Style Sheets Reference" Qt样式表的用法。

2、"Qt Style Sheets Examples" Qt样式表的实例

3、"The Style Sheet Syntax" Qt样式表语法

相关推荐
电饭叔几秒前
《python语言程序设计》2018版第8章19题几何Rectangle2D类(下)-头疼的几何和数学
开发语言·python
Eternal-Student1 分钟前
everyday_question dq20240731
开发语言·arm开发·php
卑微求AC17 分钟前
(C语言贪吃蛇)11.贪吃蛇方向移动和刷新界面一起实现面临的问题
c语言·开发语言
程序猿小D30 分钟前
第二百六十七节 JPA教程 - JPA查询AND条件示例
java·开发语言·前端·数据库·windows·python·jpa
Yvemil735 分钟前
RabbitMQ 入门到精通指南
开发语言·后端·ruby
潘多编程44 分钟前
Java中的状态机实现:使用Spring State Machine管理复杂状态流转
java·开发语言·spring
冷静 包容1 小时前
C语言学习之 没有重复项数字的全排列
c语言·开发语言·学习
碳苯1 小时前
【rCore OS 开源操作系统】Rust 枚举与模式匹配
开发语言·人工智能·后端·rust·操作系统·os
结衣结衣.2 小时前
C++ 类和对象的初步介绍
java·开发语言·数据结构·c++·笔记·学习·算法
学习使我变快乐2 小时前
C++:静态成员
开发语言·c++