C++客户端Qt开发——界面优化(QSS)

 1.QSS

如果通过QSS设置的样式和通过C++代码设置的样式冲突,则QSS优先级更高

①基本语法

选择器{属性名:属性值;
}
例如:
QPushButton {color: red;
}
1>指定控件设置样式
#include "widget.h"
#include "ui_widget.h"Widget::Widget(QWidget *parent): QWidget(parent), ui(new Ui::Widget)
{ui->setupUi(this);//应用到这个特定的按钮上ui->pushButton->setStyleSheet("QPushButton{color:red;}");//可以用颜色的英文也可以用#//ui->pushButton->setStyleSheet("QPushButton{color:#ffaa00;}");//应用到该窗口内全部的按钮上this->setStyleSheet("QPushButton{color:red;}");}Widget::~Widget()
{delete ui;
}

效果都是将QPushButton的文字颜色设置成指定颜色

2>设置全局样式

通过QApplicationsetStyleSheet方法设置整个程序的全局样式.

全局样式优点:

  • 使同一个样式针对多个控件生效,代码更简洁.
  • 所有控件样式内聚在起,便于维护和问题排查.
#include "widget.h"#include <QApplication>int main(int argc, char *argv[])
{QApplication a(argc, argv);a.setStyleSheet("QPushButton{ color:red; }");Widget w;w.show();return a.exec();
}

如果全局和QSS冲突了呢?

#include "widget.h"
#include "ui_widget.h"Widget::Widget(QWidget *parent): QWidget(parent), ui(new Ui::Widget)
{ui->setupUi(this);//局部优先级更高ui->pushButton->setStyleSheet("QPushButton{color:black; font-size:50px;}");//层叠性ui->pushButton_2->setStyleSheet("QPushButton{font-size:30px;}");}Widget::~Widget()
{delete ui;
}

QSS样式优先级更高!

除此之外,如果全局和指定控件分别设置两种不同的样式(例如pushbutton_2),那么这两种样式会叠加起来,都给该控件进行设置属性(层叠性)

3>样式和代码分离

上述设置方式比较繁琐,样式设置和C++代码混在了一起,可以把样式代码放在文件中,读取文件加载QSS内容。不过Qt Designer中直接集成了这样的功能,允许我们把样式直接写进.ui文件里(读取文件的方法不做介绍)

由于设置样式太灵活,有很多地方都能设置,就导致当某个控件样式不符合预期的时候,排查起来就比较麻烦

实际开发中,如果需要设置样式,最好统一使用某一种方式来设置

②选择器的用法

选择器

示例

说明

全局选择器

*

选择所有的widget

类型选择器

QPushButton

选择所有的QPushButton和其子类的控件

类选择器

.QPushButton

选择所有的QPushButton的控件,不会选择子类

ID选择器

#pushButton_2

选择objectNamepushButton_2的控件

后代选择器

QDialog QPushButton

选择QDialog的所有后代(子控件,孙子控件等)中的QPushButton

子选择器

QDialog>QPushButton

选择QDialog的所有子控件中的QPushButton

并集选择器

QPushButton,QLineEdit,QComboBox

选择QPushButtonQLineEditQComboBox这三种控件(样式针对这三种控件都生效)

属性选择器

QPushButton[flat="false"]

选择所有QPushButton中,flat属性为false的控件

1>使用类型选择器选中子类控件

在全局中设置

#include "widget.h"#include <QApplication>int main(int argc, char *argv[])
{QApplication a(argc, argv);a.setStyleSheet("QWidget{color:red;}");Widget w;w.show();return a.exec();
}
注意,此处选择器使用的是QWidget,QPushButton也是QWidget的子类,所以会受到QWidget选择器的影响但如果改成:a.setStyleSheet(".QWidget{color:red;}");
此时按钮的颜色不会发生改变.此时只是选择QWidget类,而不会选择QWidget的子类QPushButton
2>使用id选择器

#include "widget.h"#include <QApplication>int main(int argc, char *argv[])
{QApplication a(argc, argv);//设置全局样式QString style = "";//将所有按钮全局设置为黄色style += "QPushButton{color:yellow;}";//用id选择器设置第一个按钮为红色,第二个为绿色style += "#pushButton{color:red;}";style += "#pushButton_2{color:green;}";a.setStyleSheet(style);Widget w;w.show();return a.exec();
}

当某个控件身上,通过类型选择器和D选择器设置了冲突的样式时,ID选择器样式优先级更高

同理,如果是其他的多种选择器作用同一个控件时出现冲突的样式,也会涉及到优先级问题

Qt文档上有具体的优先级规则介绍(参见The Style Sheet Syntax的Conflict Resolution章节)

这里的规则计算起来非常复杂(CSS中也存在类似的设定),此处对于优先级不做进一步讨论

实践中我们可以简单的认为,选择器描述的范围越精准,则优先级越高。一般来说,ID选择器优先级是最高的

3>使用并集选择器

#include "widget.h"#include <QApplication>int main(int argc, char *argv[])
{QApplication a(argc, argv);a.setStyleSheet("QPushButton,QLabel,QLineEdit{color:red;}");Widget w;w.show();return a.exec();
}
4>设置下拉框的下拉按钮样式

有些控件内部包含了多个"子控件",比如QComboBox的下拉后的面板,比如QSpinBox的上下按钮等

可以通过子控件选择器::,针对上述子控件进行样式设置.

#include "widget.h"#include <QApplication>int main(int argc, char *argv[])
{QApplication a(argc, argv);QString style = "";style += "QComboBox::down-arrow{image:url(:/down.png)}";a.setStyleSheet(style);//resource.qrc内添加 down.pngWidget w;w.show();return a.exec();
}
5>修改进度条颜色

此处如果不设置alignment,进度条中的数字会跑到左上角

6>设置按钮的伪类样式

伪类选择器:是根据控件所处的某个状态被选择的.例如按钮被按下,输入框获取到焦点,鼠标移动到某个控件上等

  • 当状态具备时,控件被选中,样式生效
  • 当状态不具备时,控件不被选中,样式失效,

使用:的方式定义伪类选择器

伪类选择器

说明

:hover

鼠标放到控件上

:pressed

鼠标左键按下时

:focus

获取输入焦点时

:enabled

元素处于可用状态时

:checked

被勾选时

:read-only

元素为只读状态时

这些状态可以使用来取反.比如:!hover就是鼠标离开控件时,:!pressed就是鼠标松开时,等等

#include "widget.h"#include <QApplication>int main(int argc, char *argv[])
{QApplication a(argc, argv);QString style = "";style += "QPushButton {color:red}";style += "QPushButton:hover {color:green}";style += "QPushButton:pressed {color:blue}";a.setStyleSheet(style);Widget w;w.show();return a.exec();
}
7>用事件方式实现6中的效果

创建C++class:MyPushButton,继承父类:QPushButton

重写MyPushButton的四个事件处理函数

③样式属性 盒模型(Box Model)

一个遵守盒子模型的控件,由上述几个部分构成:

  • Content矩形区域:存放控件内容.比如包含的文本/图标等
  • Border矩形区域:控件的边框
  • Padding矩形区域:内边距,边框和内容之间的距离
  • Margin矩形区域:外边距,边框到控件geometry返回的矩形边界的距离

默认情况下,外边距,内边距,边框宽度都是0

复合属性(以margin为例)

可以拆为margin-leftmargin-rightmargin-topmargin-bottom

QSS属性

说明

margin

设置四个方向的外边距,复合属性

padding

设置四个方向的内边距,复合属性

border-style

设置边框样式

border-width

边框的粗细

border-color

边框的颜色

border

复合属性,相当于border-style+border-width+border-color

1>设置边框和内边距

#include "widget.h"#include <QApplication>int main(int argc, char *argv[])
{QApplication a(argc, argv);a.setStyleSheet("QLabel{border:5px solid red;padding-left:10px;}");//solid表示实线Widget w;w.show();return a.exec();
}
2>设置外边距

终端打印的位置还是(0,0),但是视觉上能看到不在(0,0)位置,因为加了外边框

#include "widget.h"
#include "ui_widget.h"
#include<QPushButton>
#include<QDebug>Widget::Widget(QWidget *parent): QWidget(parent), ui(new Ui::Widget)
{ui->setupUi(this);QPushButton* btn = new QPushButton(this);btn->setGeometry(0,0,100,100);btn->setText("hello");btn->setStyleSheet("QPushButton{border:5px solid red;margin:20px;}");const QRect& rect = btn->geometry(); //获取按钮的几何位置和大小。qDebug()<<rect;
}Widget::~Widget()
{delete ui;
}

④控件样式属性

1>按钮

属性

说明

font-size

设置文字大小

border-radius

设置圆角矩形,数值设置的越大,角就越圆

background-color

设置背景颜色

2>复选框

要点

说明

::indicator

子控件选择器,选中checkbox中的对钩部分

:hover

伪类选择器,选中鼠标移动上去的状态

:pressed

伪类选择器,选中鼠标按下的状态

:checked

伪类选择器,选中checkbox被选中的状态

:unchecked

伪类选择器,选中checkbox未被选中的状态

width

设置子控件宽度,对普通控件无效(普通控件使用geometry方法设定尺寸)

height

设置子控件高度,对普通控件无效(普通控件使用geometry方法设定尺寸)

image

设置子控件的图片,像QSpinBox,QComboBox等可以使用这个属性来设置子控件的图片

3>单选框

要点

说明

::indicator

子控件选择器,选中radioButton中的对钩部分

:hover

伪类选择器,选中鼠标移动上去的状态

:pressed

伪类选择器,选中鼠标按下的状态

:checked

伪类选择器,选中radioButton被选中的状态

:unchecked

伪类选择器,选中radioButton未被选中的状态

width

设置子控件宽度,对普通控件无效(普通控件使用geometry方法设定尺寸)

height

设置子控件高度,对普通控件无效(普通控件使用geometry方法设定尺寸)

image

设置子控件的图片,像QSpinBox,QComboBox等可以使用这个属性来设置子控件的图片

4>输入框

属性

说明

border-width

设置边框宽度

border-radius

设置边框圆角

border-color

设置边框颜色

border-style

设置边框风格

padding

设置内边距

color

设置文字颜色

background

设置背景颜色

selection-background-color

设置选中文字的背景颜色

selection-color

设置选中文字的文本颜色

5>列表

要点

说明

::item

选中QListView中的具体条目

:hover

选中鼠标悬停的条目

:selected

选中某个被选中的条目

background

设置背景颜色

border

设置边框

qlineargradient

设置渐变色

关于qlineargradient

qlineargradient有六个参数

x1,y1:标注了一个起点.

x2,y2:标注了一个终点.

这两个点描述了一个"方向"

例如:

  • x1:0,y1:0,x2:0,y2:1就是垂直方向从上向下进行颜色渐变.
  • x1:0,y1:0,x2:1,y2:0就是水平方向从左向右进行颜色渐变.
  • x1:0,y1:0,X2:1,y2:1就是从左上往右下方向进行颜色渐变,

stop0和stop1描述了两个颜色,渐变过程就是从stop0往stop1进行渐变的.

//从上向下渐变
QWidget{background-color:qlineargradient(x1:0,y1:0,x2:0,y2:1,stop:0 #fff,stop:1 #FFFFBF);}
//从左向右渐变
QWidget{background-color:qlineargradient(x1:0,y1:0,x2:1,y2:0,stop:0 #fff,stop:1 #FFFFDE);}
6>菜单栏

要点

说明

QMenuBar::item

选中菜单栏中的元素

QMenuBar::item:selected

选中菜单栏中的被选中的元素

QMenuBar::item:pressed

选中菜单栏中的鼠标点击的元素

QMenu::item

选中菜单中的元素

QMenu::item:selected

选中菜单中的被选中的元素

QMenu::separator

选中菜单中的分割线

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/876845.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

qt--做一个拷贝文件器

一、项目要求 使用线程完善文件拷贝器的操作 主窗口不能假死主窗口进度条必须能动改写文件大小的单位&#xff08;自适应&#xff09; 1TB1024GB 1GB1024MB 1MB1024KB 1KB1024字节 二、所需技术 1.QFileDialog 文件对话框 QFileDialog也继承了QDialog类&#xff0c;直接使用静态…

Redis缓存数据库进阶——Redis与分布式锁(6)

分布式锁简介 1. 什么是分布式锁 分布式锁是一种在分布式系统环境下&#xff0c;通过多个节点对共享资源进行访问控制的一种同步机制。它的主要目的是防止多个节点同时操作同一份数据&#xff0c;从而避免数据的不一致性。 线程锁&#xff1a; 也被称为互斥锁&#xff08;Mu…

Robot Operating System——内部审查(Introspection)Service

大纲 introspection_service检验Parameter值和类型修改内部审查&#xff08;Introspection&#xff09;功能的状态完整代码 introspection_client完整代码 测试参考资料 在ROS 2&#xff08;Robot Operating System 2&#xff09;中&#xff0c;内部审查&#xff08;Introspect…

【中项】系统集成项目管理工程师-第7章 软硬件系统集成-7.3软件集成

前言&#xff1a;系统集成项目管理工程师专业&#xff0c;现分享一些教材知识点。觉得文章还不错的喜欢点赞收藏的同时帮忙点点关注。 软考同样是国家人社部和工信部组织的国家级考试&#xff0c;全称为“全国计算机与软件专业技术资格&#xff08;水平&#xff09;考试”&…

python 裁剪图片

情况&#xff1a; 有时候看视频&#xff0c;看到一个漂亮的妹子&#xff0c;按下 Alt PrintScreen 进行截图之后&#xff0c;会把整个屏幕都截图。 需要适当剪裁一下。 每次打开 PS &#xff0c; 也太慢了。 所以写个代码&#xff0c; 快速处理。 效果对比&#xff1a; 原始…

【2025留学】德国留学真的很难毕业吗?为什么大家不来德国留学?

大家好&#xff01;我是德国Viviane&#xff0c;一句话讲自己的背景&#xff1a;本科211&#xff0c;硕士在德国读的电子信息工程。 之前网上一句热梗&#xff1a;“德国留学三年将是你人生五年中最难忘的七年。”确实&#xff0c;德国大学的宽进严出机制&#xff0c;延毕、休…

OOP知识整合----集合

目录 一、定义 1、集合: ( 不限制长度&#xff0c;存多少是多少) 2、集合框架: 二、List集合中常用的方法 1、Boolean add(Object o) 2、void add(int index,Object o) 3、Boolean remove(Object o) 4、Object remove(int index) 5、int size() 6、Boolean conta…

Code Effective学习笔记--第8章防御式编程

这一章聚焦如何通过断言和Java的异常处理机制这些防御式编程的方法来提高程序的健壮性和安全性&#xff0c;这是防御式编程技术的方面。但是健壮性和安全性到了一定的程度其实是矛盾的&#xff0c;健壮性意味着对于任何的输入&#xff0c;程序都不会终止而且都能给出返回&#…

Tftp服务器环境搭建

1、什么是Tftp TFTP&#xff08;Trivial File Transfer Protocol&#xff0c;简单文件传输协议&#xff09;是一种基于UDP&#xff08;User Datagram Protocol&#xff09;的文件传输协议&#xff0c;它被设计为一个非常简单的文件传输机制&#xff0c;特别适用于那些对复杂性有…

make2exe:自动集成测试

模板Makefile&#xff0c;生成多个C/C模块的集成测试程序。

免费【2024】springboot 基于微信小程序的宠物服务中心

博主介绍&#xff1a;✌CSDN新星计划导师、Java领域优质创作者、掘金/华为云/阿里云/InfoQ等平台优质作者、专注于Java技术领域和学生毕业项目实战,高校老师/讲师/同行前辈交流✌ 技术范围&#xff1a;SpringBoot、Vue、SSM、HTML、Jsp、PHP、Nodejs、Python、爬虫、数据可视化…

JavaDS —— 二叉搜索树、哈希表、Map 与 Set

前言 我们将学习 Map 与 Set 这两个接口下的 TreeMap 与 TreeSet &#xff0c;HashMap 与 HashSet &#xff0c;在学习这四个类使用之前&#xff0c;我们需要先学习 二叉搜索树与 哈希表的知识。 二叉搜索树 在学习二叉树的时候&#xff0c;我们就已经了解过二叉搜索树的概念…

酒店智能门锁接口pro[0922]D801 对接收银-SAAS本地化-未来之窗行业应用跨平台架构

proUSB接口函数[0922中性版]-D801 调用函数库&#xff1a; 提供Windows下的32位动态连接库proRFL.DLL&#xff0c;函数使用详细说明 //-----------------------------------------------------------------------------------// 功能&#xff1a;读DLL版本&#xff0c;不涉…

【Linux C | 网络编程】进程池退出的实现详解(五)

上一篇中讲解了在进程池文件传输的过程如何实现零拷贝&#xff0c;具体的方法包括使用mmap&#xff0c;sendfile&#xff0c;splice等等。 【Linux C | 网络编程】进程池零拷贝传输的实现详解&#xff08;四&#xff09; 这篇内容主要讲解进程池如何退出。 1.进程池的简单退…

Java并发编程(上)

并发&#xff1a;多个线程&#xff08;进程&#xff09;竞争一个资源 并行&#xff1a;多个线程&#xff08;进程&#xff09;同时运行不同资源 线程和进程的关系简单地说&#xff0c;进程是一个容器&#xff0c;一个进程中可以容纳若干个线程&#xff0c;一个进程里面&#…

微信小程序入门

创建一个入门程序 这是index.vxml代码 <!--index.wxml--> <navigation-bar title"Weixin" back"{{false}}" color"black" background"#FFF"></navigation-bar> <view class"container" ><view&…

苹果CMS:资源采集站如何设置定时采集详细教程讲解

我们搭建好站点之后&#xff0c;会自定义一些采集&#xff0c;但是需要每天去手动执行&#xff0c;有时候甚至会忘记&#xff0c;那我们如何处理呢&#xff1f;今天我们就来介绍一下如何设置定时器。 如果按照官方例子来设置定时器会遇到一个问题就是采集的资源未绑定类型&…

WAF+API安全代表厂商|瑞数信息入选IDC报告《生成式AI推动下的中国网络安全硬件市场现状及技术发展趋势》

近日&#xff0c;全球领先的权威资讯机构IDC正式发布《IDC Market Presentation&#xff1a;生成式AI推动下的中国网络安全硬件市场现状及技术发展趋势&#xff0c;2024》报告。报告中IDC 评估了众多厂商的安全硬件产品能力&#xff0c;并给出了产品对应的推荐厂商供最终用户参…

04 | 深入浅出索引(上)

此系列文章为极客时间课程《MySQL 实战 45 讲》的学习笔记&#xff01; 索引的常见模型 可以提供查询效率的数据结构有很多&#xff0c;常见的有三种&#xff1a;哈希表、有序数组、搜索数。 哈希表是一种以 key-value 形式存储的数据结构。输入一个 key&#xff0c;通过固定…

强烈推荐java人,2024年大厂面试背这份(八股文+场景题结合)!很管用!

2024 年的行情&#xff0c;和 3~4 年前不同&#xff0c;通过海量简历投递和海量面试找工作的时代已经过去了。 在如今面试机会较少&#xff0c;并且面试难度较大的情况下。 充分做好面试的准备才是快速通过面试最有效的方法&#xff01; 切忌把真实面试当靶场&#xff0c;最…