QT样式表(一)

news2024/9/25 7:25:14

目录

QSS样式表设置

1、概念

1、通过UI设计器的可视操作修改

2、通过代码修改

3、从样式文件加载

2、样式表语法

选择器的类型

3、设置背景图片

1、添加资源文件

2、使用label控件 显示头像,在样式表文件中进行设置

3、在项目中添加图片资源


QSS样式表设置

1、概念

Qt样式表(style sheet)适用于定制用户界面的机制,是受到HTML中的CSS启发而来,Qt样式表是应用于窗体界面和批量设置控件的外观,与HTML的CSS类似,Qt的样式表是纯文本的格式定义,在应用程序运行时可以载入和解析这些样式定义,从而使应用程序的界面呈现不同的效果。很多软件有换肤功能,就是使用类似于样式表的功能。

1、通过UI设计器的可视操作修改

改变按钮的文本颜色

2、通过代码修改

//设置按钮btn1的文本颜色 ui->btn1->setStyleSheet("color: rgb(255, 255, 0);");

3、从样式文件加载

一般把样式文件写到.css格式后缀的文本文件中,因为notepad++可以识别该格式打开,能很方便的带颜色显示和编辑。放到程序目录的单独的qss文件夹内,就像配置文件一样。一般通用的样式,写到一个主css文件,供整个程序加载;一些特殊样式就给所在窗口单独建一份样式文件,对该窗口加载。

第一步:建立文本文件,写入样式表内容,更改文件后缀名为qss 或者css

第二步:在工程中新建资源文件 *.qrc ,将css文件加入资源文件中,

第三步:在窗口类的构造函数中 使用代码的方式加载 样式表文件

//在文本中加载样式表 
QFile styleFile(":/qss/style.css"); 
styleFile.open(QFile::ReadOnly); 
this->setStyleSheet(styleFile.readAll()); 
styleFile.close();

2、样式表语法

一个样式法则由 一个选择器(selector)和一些声明(declaration)组成。

格式:

选择器{ 
    属性1: 值1; 
    属性2: 值2;
     ...... 
};

选择器:

  1. 通用选择器* ,表示所有组件
  2. 类型选择器,比如QPushButton,表示所有QPushButton类以及子类的组件
  3. ID选择器,比如 QPushButton#btnOK  ,表示ObjectName为btnOK的QPushButton实例
  4. ....
QLabel{
    background-color: rgb(255, 255, 0); 设置背景颜色
}
QPushButton:hover{鼠标进入控件设置背景颜色
    background:rgb(115, 183, 255);
}
QPushButton#btn1{
    border:1px solid #0000ff;  设置边框大小,边框颜色
    border-radius:50px; 设置圆角边框
    color:red; 设置字体颜色
}

选择器的类型

选择器是样式表中最重要的部分之一,它用于确定哪些控件将应用样式表。在Qt中,选择器包括类型选择器、后代选择器和类选择器。

通用选择器

通用选择器* ,表示所有组件,一般用来设置字体

*

{

        font: 14pt "Arial";

}

类型选择器

是一种基本的选择器,用于选择某种类型的控件。例如,QLabel是QLabel控件的类型选择器,或者myclass是QLabel的派生类:

QLabel {

        color: red;

}

QLabel.myclass {

        //myclass类,是继承QLabel的

        color: red;

}

后代选择器

用于选择控件的后代,即控件中嵌套的子控件。例如,选择QGroupBox控件中的QLabel控件, 和QLineEdit字体颜色设置为红色:

QGroupBox QLabel {

        color: red;

}

QGroupBox QLineEdit {

        color: red;

}

ID选择器

ID选择器用于选择具有特定ID的控件。ID选择器以"#"开头,后跟ID名。例如,选择ID为"myid"的QPushButton控件:

QPushButton#myid {

        background-color: blue;

}

这样,具有ID为"myid"的QPushButton控件的背景颜色将被设置为蓝色。

子控件选择器

子控件选择器用于选择控件的子控件并对其应用样式子控件选择器以"::"开头,后跟子控件类型。例如,选择QComboBox控件的下拉箭头:

QComboBox::down-arrow {

        image: url(arrow.png);

}

这样,QComboBox控件的下拉箭头图像将被设置为"arrow.png"。

状态选择器

状态选择器用于选择具有特定状态的控件。例如,选择被按下的QPushButton控件:

QPushButton:pressed

{

        background-color: yellow;

}

这样,被按下的QPushButton控件的背景颜色将被设置为黄色。

3、设置背景图片

1、添加资源文件

选择工程目录右击--》添加新文件---》Qt--》QtResource file---》添加--》添加前缀--》添加文件

2、使用label控件 显示头像,在样式表文件中进行设置

QLabel#label_2{ 
    border-radius:50px; 
    border-image: url(:/imags/imags/1.jpg); 
}

3、在项目中添加图片资源

图片格式:jpg ,png

实现步骤:

第一步:在工程项目目录下,创建一个目录--- image,并将图片拷贝到目录 下

第一步:在工程项目目录下,创建一个目录--- image,并将图片拷贝到目录 下

第二步:右击项目 ---- > new ---> 在弹出的对话框中,设置如下图所示。

继续点击下一步,完成即可。

第三步:添加文件

在添加文件之前,要先设置一个前缀

设置完前缀后,再点击添加按钮,然后选择要添加的文件。

第四步:保存文件

第五步:给控件使用图片资源 --- ui文件中使用

第六步,在代码中,使用图片资源

ui‐>label‐>setStyleSheet("border‐image: url(:/image/off.png);");

第七步:如何实现资源图片的再次添加

一个按钮两种状态,改变图片的背景图片:

//灯按钮 
void MainWindow::on_ledbtn_clicked() { 
    if(isLedState==false)
    {
         isLedState = true; 
         ui->ledbtn->setStyleSheet("border-image: url(:/image/on.png);");
    }else{
         isLedState = false; ui->ledbtn->setStyleSheet("border-image: url(:/image/off.png);"); 
    }
}

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

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

相关文章

动态规划入门之二维数组的动态规划(过河卒)

P1002 [NOIP2002 普及组] 过河卒 - 洛谷 | 计算机科学教育新生态 (luogu.com.cn) 过河卒,首先科普一下象棋里面的马的跳跃一步的规则吧(这题真够坑人的,连个规则都不给出,害得我第一次交就全wa)。一张图解释 大家看所…

Nvidia Jetson 编解码开发(4)H265解码图像异常问题调试

1. 前言 基于此贴继续验证H265图像 Nvidia Jetson 编解码开发(3)解决H265解码报错“PPS id out of range”_free-xx的博客-CSDN博客 ffmpeg解码后图像颜色异常 2. 梳理YUV格式顺序 相机输出图像格式: YUV422 8bit, UYVY 由于编码模块输入必须是 YUV420, 不能是YUV…

SpringCloud Ribbon中的7种负载均衡策略

SpringCloud Ribbon中的7种负载均衡策略 Ribbon 介绍负载均衡设置7种负载均衡策略1.轮询策略2.权重策略3.随机策略4.最小连接数策略5.重试策略6.可用性敏感策略7.区域敏感策略 总结 负载均衡通器常有两种实现手段,一种是服务端负载均衡器,另一种是客户端…

内网渗透神器CobaltStrike之权限提升(七)

Uac绕过 常见uac攻击模块 UAC-DLL UAC-DLL攻击模块允许攻击者从低权限的本地管理员账户获得更高的权限。这种攻击利用UAC的漏洞,将ArtifactKit生成的恶意DLL复制到需要特权的位置。 适用于Windows7和Windows8及更高版本的未修补版本 Uac-token-duplication 此攻…

软件测试开发实战|接口自动化测试框架开发(pytest+allure+aiohttp+用例自动生成)

近期准备优先做接口测试的覆盖,为此需要开发一个测试框架,经过思考,这次依然想做点儿不一样的东西。 接口测试是比较讲究效率的,测试人员会希望很快能得到结果反馈,然而接口的数量一般都很多,而且会越来越…

鼎友餐饮信息总监杨山海:餐饮新增长依托数智应用,用数字化打造单店盈利模型

杨山海 鼎友餐饮信息总监 近20年餐饮行业信息化、数字化决策经验,曾担任新辣道、雕刻时光、青年餐厅、快乐蜂、鲜果时间信数化负责人,主抓数字化转型、系统选型、多接口系统管理等,拥有丰富的餐饮行业数字化转型经验。 2000年,杨…

vue快捷生成初始代码模板

1.在 vscode 中找到如图设置->代码片段->vue.json 2.配置默认值 {"vue3": {"prefix": "vue3","body": ["<template>"," <div></div>","</template>","",&qu…

【HCIP】09.路由引入

路由引入&#xff1a;路由优先级 路由引入&#xff1a;路由回灌 场景描述 R1访问目标地址5.5.5.5&#xff0c;如果数据发给R3就会形成路由回灌R1访问5.5.5.5时&#xff0c;查询路由表&#xff0c;发现5.5.5.5是R3将ISIS引入产生的路由&#xff0c;则将下一跳指向R3R3收到数据包…

arm:day7

1.软中断处理 .text 文本段 .global _start 声明一个_start全局函数的入口 _start: _start标签&#xff0c;就是c语言的函数 1.构建异常表b resetb undefb softwareb prefetchb datab irqb fiqreset: 2.系统上电&#xff0c;程序运行在svc模式 初始化svc模式的栈指针ldr sp,0x4…

财报解读:“三驾马车”驱动,劲仔食品能否越跑越快?

国内休闲零食市场上半年表现喜人。 8月以来&#xff0c;多家休闲零食上市公司发布半年报告或预告&#xff0c;纷纷迎来利润增长。盐津铺子预计2023年上半年实现扣除非经常性损益后的净利润2.26亿元至2.36亿元&#xff0c;同比增长98.89%至107.69%&#xff1b;甘源食品预计2023…

【Java转Go】快速上手学习笔记(四)之基础篇三

目录 泛型内置泛型的使用切片泛型和泛型函数map泛型泛型约束泛型完整代码 接口反射协程特点WaitGroupgoroutine的调度模型&#xff1a;MPG模型 channel介绍语法&#xff1a;举例&#xff1a;channel遍历基本使用和协程一起使用案例一案例二 select...casemain.go 完整代码 文件…

备份服务器搭建

备份服务器搭建 1、背景2、作用3、选型4、环境5、部署5.1、服务端部署5.1.1、安装5.1.2、配置 5.2、客户端部署5.3、备份策略5.3.1、定时备份策略5.3.2、文件变动备份 6、参考 1、背景 随着项目的推进&#xff0c;备份服务器被提上了工作日程&#xff0c;等保、密评和接入测评…

三层交换机实验

要求&#xff1a; 目录 1、IP规划 2、交换机的配置 2.1 Eth-Trunk通道&#xff08;将多个接口逻辑的整合成一个接口&#xff0c;实现带宽叠加的作用&#xff09; 2.2 创建VLAN&#xff08;所有交换机只创建VLAN2&#xff0c;默认有VLAN1&#xff09; 2.3 创建trunk干道…

PHP“牵手”拼多多商品详情数据获取方法,拼多多API接口批量获取拼多多商品详情数据说明

拼多多商品详情接口 API 是开放平台提供的一种 API 接口&#xff0c;它可以帮助开发者获取拼多多商品的详细信息&#xff0c;包括商品的标题、描述、图片等信息。在拼多多电商平台的开发中&#xff0c;拼多多详情接口 API 是非常常用的 API&#xff0c;因此本文将详细介绍拼多多…

6.RocketMQ之文件查询索引文件IndexFile

根据消息ID来查找消息&#xff0c;consumequeue 中没有存储消息ID,如果不采取其他措施&#xff0c;又得遍历 commitlog文件了&#xff0c;indexFile就是为了解决这个问题的文件。 如图所示&#xff1a; 一个indexFile对应一个40个字节的IndexHead。(40,2000 0000]区间代表存放…

【深入解析:数据结构栈的魅力与应用】

本章重点 栈的概念及结构 栈的实现方式 数组实现栈接口 栈面试题目 概念选择题 一、栈的概念及结构 栈&#xff1a;一种特殊的线性表&#xff0c;其只允许在固定的一端进行插入和删除元素操作。进行数据插入和删除操作的一端 称为栈顶&#xff0c;另一端称为栈底。栈中的数…

行政区划表设计和多级查询

简介 行政区划的表为一个多层级结构&#xff0c;设计大同小异&#xff0c;大致结构如下所示 其中&#xff0c;code为区划编号&#xff08;主键&#xff09;&#xff0c;parent_code为父区划编号&#xff0c;ancestors为祖区划编号&#xff0c;查询也主要围绕前两个展开。 查询…

【后端】Core框架版本和发布时间以及.net 6.0启动文件的结构

2023年&#xff0c;第35周&#xff0c;第1篇文章。给自己一个目标&#xff0c;然后坚持总会有收货&#xff0c;不信你试试&#xff01; .NET Core 是一个跨平台的开源框架&#xff0c;用于构建现代化的应用程序。它在不同版本中有一些重要的区别和发布时间 目录 一、Core版本和…

新研究:Gartner 公有云成本管理框架

2023年6月28日&#xff0c;Gartner 出版了名为《Beyond FinOps: the Gartner Framework for Public Cloud Financial Management》的公有云成本管理框架&#xff0c;旨在帮助企业/组织应对公有云支出的挑战&#xff0c;同时抓住新机遇&#xff0c;推动更有效的 IT 使用。新框架…

【HCIP】05.OSPF邻居与邻接关系

报文 OSPF头部 报文头部中影响邻居关系建立的字段是Router ID、Area ID、AuType HELLO报文 报文中影响建立邻居关系到是 hello time时间&#xff0c;DR优先级等 DD报文 序列号&#xff0c;LSA头部摘要信息I位&#xff1a;第一个报文&#xff0c;用于主从选举M位&#xff1a;…