【Qt】控件样式案例

news2024/9/20 14:27:19

例子:设置按钮样式

(1)设置一个按钮

(2)右键按钮,选择样式表

(3)编写全局样式

font-size 设置字体大小;

border-radius 设置圆角矩形;

background-color 设置背景色;

color 设置文字颜色;

(3)编写伪类选择器

例子:设置复选框样式

要点说明
::indicator
⼦控件选择器.
选中 checkbox 中的对钩部分.
:hover
伪类选择器.
选中⿏标移动上去的状态.
:pressed
伪类选择器.
选中⿏标按下的状态.
:checked
伪类选择器.
选中 checkbox 被选中的状态.
:unchecked
伪类选择器.
选中 checkbox 未被选中的状态.
width
设置⼦控件宽度.
对于普通控件⽆效 (普通控件使⽤ geometry ⽅式设定尺⼨).
height
设置⼦控件⾼度.
对于普通控件⽆效 (普通控件使⽤ geometry ⽅式设定尺⼨).
image
设置⼦控件的图⽚.
像 QSpinBox, QComboBox 等可以使⽤这个属性来设置⼦控件的图⽚.

(1)创建⼀个 resource.qrc ⽂件, 并导⼊以下图⽚

使⽤⿊⾊作为默认形态.
使⽤绿色作为 hover 形态.
使⽤红⾊作为 pressed 形态.

 

(2)创建一个复选框

(3)编写复选框样式

QChechBox { 
	font-size : 50px;
}

QCheckBox::indicator {
	width : 50px;
	height : 50px;
}

QCheckBox::indicator:unchecked {
	image : url(:/201uncheckboxBlack.png);
}

QCheckBox::indicator:unchecked:hover{
	image : url(:/201uncheckboxGreen.png);
}

QCheckBox::indicator:unchecked:pressed{
	image : url(:/201checkboxRed.png);
}

QCheckBox::indicator:checked {
	image : url(:/201checkboxBlack.png);
}

QCheckBox::indicator:checked:hover{
	image : url(:/201checkboxGreen.png);
}

QCheckBox::indicator:checked:pressed{
	image : url(:/201uncheckboxRed.png);
}

(4)执行程序

例子:设置单行编辑框样式

属性说明
border-width
设置边框宽度.
border-radius
设置边框圆⻆.
border-color
设置边框颜⾊.
border-style
设置边框⻛格.
padding
设置内边距.
color
设置⽂字颜⾊.
background
设置背景颜⾊.
selection-background-color
设置选中⽂字的背景颜⾊.
selection-color
设置选中⽂字的⽂本颜⾊.

(1)设置一个lineEdit

(2)编写样式

(3)运行程序

例子:设置列表框样式

要点说明
::item
选中 QListView 中的具体条⽬
:hover
选中⿏标悬停的条⽬
:selected
选中某个被选中的条⽬.
background
设置背景颜⾊
border
设置边框
qlineargradient
设置渐变⾊

(1)设置listView

(2)编写纯色样式

(3)编写渐变色样式 

纯色:选中的区域中,各个位置的颜色都是一样的;

渐变色:左侧一个颜色,右侧一个颜色,左侧颜色逐渐向右侧颜色改变

在Qt中使用qlineargradient 设置渐变色(线性渐变)

此处需要填写 6 个参数:(这里的坐标取值是非常有限的,要么是 0 ,要么是 1)

  • x1 : 起点的横坐标
  • y1 : 起点的纵坐标
  • x2 : 终点的横坐标
  • y2 : 终点的纵坐标
  • stop : 0 起始颜色
  • stop : 0 结束颜色

例子:设置菜单栏样式

要点说明
QMenuBar::item
选中菜单栏中的元素.
QMenuBar::item:selected
选中菜单来中的被选中的元素.
QMenuBar::item:pressed
选中菜单栏中的⿏标点击的元素
QMenu::item
选中菜单中的元素
QMenu::item:selected
选中菜单中的被选中的元素
QMenu::separator
选中菜单中的分割线

(1)设置菜单栏、菜单以及菜单项

(2)设置样式

例子:设置背景

(1)设置多个控件

(2)使用qrc导入图片

(3)设置背景 

直观想法是直接给QWidget顶层窗口设置背景图片,但是Qt中存在限制,直接给顶层窗口设置背景会失效(原因不可靠),但是可以给上述控件外面套上一个和窗口一样大小的QFrame控件。

在Qt中设置背景图,除了background-image之外,还有border-image属性。

主要是因为 border-image 是可以⾃动缩放的. 这⼀点在窗⼝⼤⼩发⽣改变时是⾮常有意义的

(4)运行程序

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

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

相关文章

数据结构-树(基础,分类,遍历)

数据结构-树 1.什么是树? 在计算机科学中,树是一种常用的非线性数据结构,用于表示具有层次关系的数据。与线性数据结构(如数组和链表)不同,树结构以节点(Nodes)和边(Ed…

日元走强引领外汇市场新动向,全球经济指标波动加剧

日元看涨情绪升温 近期,外汇市场上日元成为焦点,对冲基金纷纷增加对日元上涨的期权投注,预计其将延续本季度强劲表现。上周五,美元兑日元收跌0.65%,盘中触及年内低点,显示出市场对日元未来走势的乐观预期。…

一文了解什么是TTP — 技术、战术与程序

导语:TTP的概念最早来自于军事领域及反恐活动,后面逐渐被应用到网络安全领域,在网络安全中,TTP(技术、战术与程序)是一个核心概念,它涵盖了攻击者使用的工具、技术和方法,以及他们执…

HTML+CSS - 网页布局之多列布局定位

1. 多列布局 CSS中多列布局处理文本内容&#xff0c;特别适合对于长段落或者大量文本进行自动分栏显示 类似于grid分布&#xff0c;但相较之下更加简洁明了 基本语法 <div class"container"><p>这是一些示例文本&#xff0c;当我们使用 column-count…

SpringBoot Kafka发送消息与接收消息实例

前言 Kafka的基本工作原理 我们将消息的发布&#xff08;publish&#xff09;称作 producer(生产者)&#xff0c;将消息的订阅&#xff08;subscribe&#xff09;表述为 consumer&#xff08;消费者&#xff09;&#xff0c;将中间的存储阵列称作 broker(代理)&#xff0c;这…

酷炫的航模直升机技术详解

1. 分类与级别&#xff08;400级至90级&#xff09; 航模直升机以其独特的飞行魅力和高难度的操作技巧&#xff0c;吸引了众多飞行爱好者。根据模型的尺寸、重量、动力系统及飞行性能&#xff0c;航模直升机大致可分为多个级别&#xff0c;从入门级的400级到专业级的90级及以上…

简单接口自动化框架实现(Python+requests+pytest)

1、接口自动化流程 1.需求分析2.挑选需要做自动化测试的功能3.设计测试用例4.搭建自动化测试环境[可选]5.设计自动化测试项目的架构[可选]6.编写代码7.执行测试用例8.生成测试报告并分析结果 2、框架结构 --api -->封装请求 --scripts -->编写测试脚本…

15. Springboot集成Redis

目录 1、前言 2、为什么选择Spring Boot集成Redis&#xff1f; 3、快速上手 3.1、引入依赖 3.2、 配置连接信息 3.3、自定义配置类 4、RedisTemplate的使用 4.1、String类型操作 4.2、 Hash类型操作 4.3、List类型操作 4.4、Set类型操作 4.5、SortedSet类型操作 4…

有了数据中台,是否需要升级到数据飞轮?怎么做才能升级到数据飞轮?

在数字化转型的时代&#xff0c;企业纷纷建设了“数据中台”&#xff0c;把各种业务数据整合在一起&#xff0c;仿佛是将所有材料都整理进了厨房的储物柜。 但是问题是&#xff1a;光有储物柜&#xff0c;能做出好吃的菜吗&#xff1f;答案显然是否定的。想要真正利用这些数据…

华为HarmonyOS地图服务 -- 如何实现地图呈现?-- HarmonyOS自学8

如何使用地图组件MapComponent和MapComponentController呈现地图&#xff0c;效果如下图所示。 MapComponent是地图组件&#xff0c;用于在您的页面中放置地图。MapComponentController是地图组件的主要功能入口类&#xff0c;用来操作地图&#xff0c;与地图有关的所有方法从此…

项目实现:云备份③(配置文件加载模块、数据管理模块的实现)

云备份 前言配置文件加载模块配置信息的设计单例文件配置类设计 数据管理模块数据信息类设计数据管理类实现数据持久化存储初始化加载实现 前言 书接上回&#xff1a;云备份&#xff08;实用工具类&#xff09;实现后&#xff0c;接下来会逐步实现不同模块的功能。会频繁用到工…

更主动的对话规划者:PPDPP论文解读

摘要 主动对话在大语言模型&#xff08;LLMs&#xff09;时代中是一个实际且具有挑战性的对话问题&#xff0c;其中对话策略规划是提升LLMs主动性的重要关键。现有的大多数研究通过各种提示方案或使用口头AI反馈迭代增强处理特定案例的能力&#xff0c;以实现LLMs的对话策略规…

元宇宙+教育:打造个性化、互动化学习生态系统!

近两年来&#xff0c;元宇宙风在全球迅速掀起了一股新浪潮。“元宇宙”成为各个行业的热门发展方向&#xff0c;各个行业正试图通过元宇宙寻求新的发展突破口&#xff0c;教育行业也不例外。 教育培训元宇宙作为一种前沿的教育模式&#xff0c;深度融合了虚拟现实、增强现实及…

SAP HCM HR_MAINTAIN_MASTERDATA自带解锁功能

导读 锁功能&#xff1a;在SAP HCM模块有针对人的加锁功能&#xff0c;今天遇到的一个问题是&#xff0c;人员无法被锁住&#xff0c;给我第一反应就是代码没有加锁&#xff0c;代码有问题&#xff0c;但是去看代码系统确实已经加锁&#xff0c;但是系统还是提示这个&#xff…

BPF 调度器 sched_ext 实现机制、调度流程及样例

本文地址&#xff1a;https://www.ebpf.top/post/bpf_sched_ext_dive_into 在文章 Linus 强势拍板合入: BPF 赋能调度器终成正果中&#xff0c;我们回顾了 BPF 在调度器在合入社区过程中的历程&#xff0c;补丁 V7 已经在为合并到 6.11 做好了准备&#xff0c;后续代码仓库也变…

4. 认识 LoRA:从线性层到注意力机制

如果你有使用过 AI 生图&#xff0c;那你一定对 LoRA 有印象&#xff0c;下图来自Civitai LoRA&#xff0c;上面有很多可供下载的LoRA模型。 你可能也曾疑惑于为什么只导入 LoRA 模型不能生图&#xff0c;读下去&#xff0c;你会解决它。 文章目录 为什么需要 LoRA&#xff1f;…

预训练数据指南:衡量数据年龄、领域覆盖率、质量和毒性的影响

前言 原论文&#xff1a;A Pretrainer’s Guide to Training Data: Measuring the Effects of Data Age, Domain Coverage, Quality, & Toxicity 摘要 预训练是开发高性能语言模型&#xff08;LM&#xff09;的初步和基本步骤。尽管如此&#xff0c;预训练数据的设计却严…

STM32 HAL freertos零基础(十一)中断管理

1、简介 在FreeRTOS中,中断管理是一个重要的方面,尤其是在嵌入式系统中。正确地处理中断可以确保系统的实时响应能力,并且能够在中断服务程序(ISR)中执行关键操作。FreeRTOS提供了一些机制来帮助开发者管理中断,并确保在多任务环境下中断处理的安全性和高效性。 任何中…

【AI大模型】Transformer模型:Postion Embedding概述、应用场景和实现方式的详细介绍。

一、位置嵌入概述 \1. 什么是位置嵌入&#xff1f; 位置嵌入是一种用于编码序列中元素位置信息的技术。在Transformer模型中&#xff0c;输入序列中的每个元素都会被映射到一个高维空间中的向量表示。然而&#xff0c;传统的自注意力机制并不包含位置信息&#xff0c;因此需要…

3CCD的工作原理

昨天看编辑送的一本《计算机视觉》中3CCD的工作原理错了&#xff0c;其实是百度百科错了&#xff0c;所以我想有人就照搬照抄错了。专业问题不要问百度&#xff0c;百度就是骗子一样的存在&#xff0c;这么多年就从来没有把心思放在做事上。3CCD通过光学棱镜分光后就已经是单色…