Qt 样式设置

news2025/7/8 2:55:13

Qt 样式设置

  • 样式语法
    • 指定控件 Selector Types
    • 盒子模型 The Box Model
    • 能自定义样式的控件
    • Sub-Controls
    • 控件的状态 Pseudo-States
    • 属性
    • 内置图标
    • 多个设置冲突
    • 层叠样式 Cascading
    • 继承规则 Inheritance
  • 子窗口不继承父窗口样式
  • 移除控件旧样式
  • 添加 .qss 文件
  • Qt 预置颜色
  • QLineEdit 样式设置
  • QPushButton

Qt 帮助文档 The Style Sheet Syntax
CSS 教程
CSS2 Selectors

样式语法

1

Qt Style Sheet 语法不区分大小写:

1

指定控件 Selector Types

selectors defined in CSS2

对控件设置样式是可以限定范围,如根据控件名字,或者某一类控件但不包括子控件等,常用的类型如下:

2

如根据 Object name 来设置某类控件样式:

QWidget#widget_a,QWidget#widget_b
{
    background-color:#000000;
}

盒子模型 The Box Model

CSS 盒子模型

1在这里插入图片描述

能自定义样式的控件

Qt 中查看 List of Stylable Widgets 的位置如下:

1

部分截图:


1

Sub-Controls

Qt中的QSS Subcontrol

1
3在这里插入图片描述

List of Sub-Controls 位置:

1

2


4
5

控件的状态 Pseudo-States

控件在不同状态下的样式,如 QPushButton 在按下(pressed)或悬浮(hover)状态下设置不同的背景颜色。

1

7
8
9

属性

List of PropertiesList of Sub-Controls 查找方法相同。

1

内置图标

Qt 内置图标的介绍和使用

List of IconsList of Sub-Controls 查找方法相同。

QIcon icon = QApplication::style()->standardIcon(QStyle::QStyle::SP_ComputerIcon);
ui->pushButton->setIcon(icon);

QPixmap pic = icon.pixmap(icon.actualSize(QSize(64,64)));
ui->label->setPixmap(pic);

多个设置冲突

CSS2 Specification

12

同一个控件同时在 .qss 文件,ui 文件和代码中设置样式,其优先级为:
代码中指定样式 > ui 文件中通过 styleSheet 设置样式 > .qss 中设置样式。

层叠样式 Cascading

6.4 The cascade
Qt样式表之一:Qt样式表和盒子模型介绍

1

继承规则 Inheritance

2

子窗口不继承父窗口样式

QT5 子窗口不继承父窗口的边框、背景等风格

在界面中指定某个窗口的样式,如背景颜色等,指定名称,不影响子控件。

ID selectors 介绍: 5.9 ID selectors

如:在一个 QFrame 中添加一个 QComboBox,将 QFrame 的背景设置为透明样式,且不指定具体名字,发现 QComboBox 的下拉窗体背景颜色无法设置,而指定 QFrame 名字后正常。

QFrame 不设置透明样式,指定背景颜色,在里面添加的 QComboBox 的下拉框每个条目的背景颜色是 QFrame 的背景颜色,指定 QFrame 名字后正常。

移除控件旧样式

飞扬青云 / Qt开发经验

添加 .qss 文件

可以建一个 .qss 文件来设置应用程序的样式,或者建立几种不同的风格可以切换,如对所有的按钮统一设置样式,保持风格统一,程序里加载 .qss 文件。

程序的目录如下:

1

工程中添加资源文件方法:Qt资源文件。

 QFile file(QString(":/resource/style.qss"));
 file.open(QFile::ReadOnly);
 QString strQss = QLatin1String(file.readAll());
 qApp->setStyleSheet(strQss);

同一个控件同时在 .qss 文件,ui 文件和代码中设置样式,其优先级为:
代码中指定样式 > ui 文件中通过 styleSheet 设置样式 > .qss 中设置样式。

Qt 预置颜色

在这里插入图片描述

QLineEdit 样式设置

可以在 .qss 的文件统一设置样式。

.QLineEdit{
        width:400px;
        height:40px;
        font-family: "Microsoft YaHei";
        font-size: 16px;
	    padding: 2px;
   		color:blue;
        background-color: #BDB76B;
		selection-color: red;
		seletion-background-color: #696969;
}

.QLineEdit[echoMode="2"] {
        lineedit-password-character: 9679;
}

.QLineEdit:focus{
    border: 1px solid #DC143C;
}
.QLineEdit:hover{
    border: 1px solid #DB7093;
}

.QLineEdit:!enabled{
   color:gray;
   background-color: #7FFF00;
}

selection-color 设置选中文本时的文本的颜色,seletion-background-color 设置选中文本时的背景颜色。
widthheight 可以在 ui 界面设置,界面设置后以界面设置的为准。

1

QPushButton

CSS 按钮
Qt 帮助文档 Qt Style Sheets Examples ----- Customizing QPushButton

.QPushButton{
	background-color: black;
	border: 2px solid #4CAF50; /* Green */
	border-radius: 50%;
	color: white;
	font: bold 14px;
	padding: 5px;	
	min-height: 20px;
	text-align: center;
    text-decoration: none;
    display: inline-block;
	box-shadow: 0 12px 16px 0 rgba(0,0,0,0.24), 0 17px 50px 0 rgba(0,0,0,0.19);
}

.QPushButton:disabled{
    background-color: #696969;
    color:#C0C0C0;
}

.QPushButton:hover{ 
	background-color: #696969;
    color:#C0C0C0;
}

.QPushButton:pressed{ 
	background-color: #696969;
    color:#C0C0C0;
}

.QPushButton:checked{
    color: #808000;
    background-color: #8B4513;
}

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

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

相关文章

创建一个中国人的类

/*** 创建一个中国人的类* 分析:* 1、每个中国人都有一个唯一的身份证号码,所以身份证号码属性需要定义成实例变量* 2、每个人的姓名也都是不一样的,为此姓名属性也需要定义成实例变量* 3、每个中国人的国籍…

python实现目标检测voc格式标签数据增强

文章目录前言一、显示图片(可关闭)二、创建图像变换的类1.增强数据代码2.图像加噪声3.调整图像亮度4.添加黑色像素块5.旋转图像6.图像裁剪7.平移图像8.图像镜像9.图像随机增强选择三、增强后图片保存与xml解析保存1.从xml文件中提取bounding box信息2.保…

数据结构:循环队列

之前已经做过队列的学习笔记,这一篇写的是循环队列,大部分代码可以继续沿用,某些地方需要作出更改,使其可以实现循环队列的功能。 通俗的总结一下队列的操作,我的思路是将头指针固定不动,然后每一次元素入…

模拟实现string

第一部分:构造,析构,拷贝构造,赋值重载,打印函数这几个大头写出来先 string类框架 namespace xxx { class string { public: // //private: char* _str; size_t _size; size_t _capacity;const static size_t npos -…

计算机视觉——python在一张图中画多条ROC线

在验证分类算法的好坏时,经常需要用到AUC曲线,而在做不同分类模型的对比实验时,需要将不同模型的AUC曲线绘制到一张图里。 计算机视觉——python在一张图中绘制多个模型的对比ROC线1. 小型分类模型对比,可以直接调用的2. 大型的CN…

七夕,程序员教你5个表白代码,2分钟学会,牢牢主抓她的心

七夕。一个有人欢喜有人愁的节日,虽然对一些单身人士不太友好,但还有不少人都在等这个节日进行表白。毕竟这个日子的成功率会高一些。 情人节少不了送花送礼物,作为一个程序员,当然不会在送什么礼物上给你指点一二,但…

适合骑车时候戴的耳机怎么选,列举五款在骑行佩戴的耳机推荐

相信大多数人在运动的过程中都会感觉到枯燥无力的感觉,为此也一直在寻找一些能够让我们在运动中保持最初的热诚,在最终的选择上,绝大多数都是选择了耳机,因为耳机能够产生美妙的音乐,将我们运动的枯燥做进一步的抵消&a…

【附源码】Python计算机毕业设计网络教育平台设计

项目运行 环境配置: Pychram社区版 python3.7.7 Mysql5.7 HBuilderXlist pipNavicat11Djangonodejs。 项目技术: django python Vue 等等组成,B/S模式 pychram管理等等。 环境需要 1.运行环境:最好是python3.7.7,…

【HMS Core】定位服务无法获取街道信息问题

问题描述: 华为HMS-定位服务无法获取省市街道信息 背景:在手机上集成华为定位服务的功能运行后,只能获取到经纬度,无法得到具体地址(城市/街道/建筑)。 配置环境:(1)手机型号:Red…

c语言实现通讯录(用三种方法来实现一个属于你的通讯录)

前沿: ~~在一个周前,我用c语言实现了一个银行账号的功能,在总结当中我说了要实现一个通讯录,来实现人员的增删插改功能,而现在就是我实现它的时候!!,本文呢小…

基于python命令流及代码的Plaxis自动化建模

有限单元法在岩土工程问题中应用非常广泛,很多商业软件如Plaxis/Abaqus/Comsol等都采用有限单元解法。在使用各大软件进行数值模拟建模的过程中,您是否发现GUI界面中重复性的点击输入工作太繁琐?从而拖慢了设计或方案必选进程? 本…

SpringBoot八种bean的加载方式一学就会

目录 文章目录[toc]第一种bean的加载方式-配置文件第二种加载bean方式-注解和扫描创建第三方的bean对象第三种加载bean方式-不使用配置文件扩展-bean的加载方式扩展FactoryBean<>扩展-ImportResource导入配置文件扩展-proxyBeanMethods属性-产生代理对象第四种加载bean方…

一文读懂,python实现常用的数据编码和对称加密

相信很多使用 python 的小伙伴在工作中都遇到过&#xff0c;对数据进行相关编码或加密的需求&#xff0c;今天这篇文章主要给大家介绍对于一些常用的数据编码和数据加密的方式&#xff0c;如何使用 python 去实现。话不多说&#xff0c;接下来直接进入主题&#xff1a; 1、bas…

Windows OpenGL ES 图像灰度图

目录 一.OpenGL ES 图像灰度图 1.原始图片2.效果演示 二.OpenGL ES 图像灰度图源码下载三.猜你喜欢 零基础 OpenGL ES 学习路线推荐 : OpenGL ES 学习目录 >> OpenGL ES 基础 零基础 OpenGL ES 学习路线推荐 : OpenGL ES 学习目录 >> OpenGL ES 特效 零基础 Open…

Redis添加至windows服务

1.进入redis文件夹 打开redis所在文件夹&#xff0c;在资源管理器地址栏输入cmd&#xff0c;打开管理员命令提示符窗口。 2.配置服务参数 打开redis.windows.conf文件&#xff0c;找到“requirepass”配置项&#xff0c;此处设置redis密码&#xff0c;如果不需要密码&#xff0…

Python如何使用HanNLP工具

Python如何使用HanNLP工具目录系统安装配置 JDK 1.8系统安装 Visual C 2015下载 HanNLP 包测试HanNLP工具目录 目标&#xff1a;使用pycharm调用HanNLP工具完成对文本的分词、自动摘要、关键词提取等任务。 系统安装配置 JDK 1.8 1、windows环境下载 JDK 1.8 2、安装 JDK 1.…

Oracle PrimaveraUnifier空间管理器(Space Manager)

目录 前言 介绍 前言 在Oracle Primavera Unifier设施和资产管理基础产品中除了业务流程及配置管理器之外&#xff0c;其预配置设计还包含本文要介绍的空间管理器&#xff0c;即Space Manager 在Unifier中&#xff0c;空间管理器是用户可以执行设施管理任务的地方。空间管…

xv6---Lab1: Xv6 and Unix utilities

目录 参考资料&#xff1a; 1.1进程和内存 1.2 I/O 和文件描述符 1.3管道 源码&#xff1a; 调试环境搭建 sleep PingPong primes find xargs 参考资料&#xff1a; Lab: Xv6 and Unix utilities xv6-book翻译(自用&#xff09;第一章 - 知乎 1.1进程和内存 一个xv…

html中css的基础学习

小李胖了吗 I 都说秋天适合思念&#xff0c;其实更适合见面【小李胖了吗 I 都说秋天适合思念&#xff0c;其实更适合见面】 https://www.bilibili.com/video/BV19g411B7uL/?share_sourcecopy_web&vd_source385ba0043075be7c24c4aeb4aaa73352 通过本博文的学习&#xff0c…

常见的软件测试面试题,千万别答错了

软件测试的童鞋们&#xff0c;在面试测试工作时&#xff0c;一定遇到面试官问过这个问题&#xff1a; 软件测试的目的意义是什么&#xff1f;大家是怎么回答的呢&#xff1f;如果这个问题回答好了&#xff0c;说明你对软件测试工作的价值与意义了如指掌。 有经验的测试人员可…