上一篇文章中,我们已经了解了QSS的基础使用,现在我们将会看到一个简单的例子来加深对QSS的理解。

需求分析

我们想要在界面中让文本显示出指定的颜色,现在有几种方案:

  1. 使用paintEvent手动计算文字大小和位置,然后绘制
  2. 利用QLabel可以识别HTML标签的特性实现彩色文字
  3. 利用QSS+QLabel实现彩色文字

我们逐一分析这三种方案的利弊。

首先是paintEvent的方案,这是三种方案中最灵活却也是最复杂的,通过重绘事件可以最大限度的发挥其灵活性,但对于字体大小的计算以及文字对齐的控制都需要自行处理,如此一来工程量不可谓不大,显然对于我们只是希望让文字显示出指定颜色的简单需求来说实现成本过高了。

其次是使用HTML标签的方案,这种方案的好处在于QLabel已经帮我们处理了文字的绘制和对齐,我们只需要将合适的HTML内容添加进去即可,虽然灵活性不如第一种,但是其简便性是显而易见的,例如:

label = QLabel(r'<font color="#ff0000">Qt</font>')
label.show()

这将会显示一个红色的“Qt”文字。

然而该方案的缺点也是显而易见的,虽然QLabel识别了HTML标签并且不会明文显示,但它确是实际存在于label中的:

print(label.text()) # '<font color="#ff0000">Qt</font>'

当我们需要设置/获取label中的文字时,就不得不想办法去除这个HTML标签,又或者当我们想要修改label的颜色时,就不得不对text做更复杂的处理,显然,我们的需求中也会包含以上类似的场景,所以这种看起来简单实际上暗含了复杂性的方案我也没有采用。事实上开发中经常会出现这种坑,所以在方案选择时三思而后行总是有好处的。

最后一种是QSS+QLabel的方案,也是目前我采用的方案。你可能已经猜到了,这种方案兼具QLabel的实用和QSS的简单,也不会在内部保存多余的信息,在牺牲部分灵活性的前提下是最简单也是最合适的解决方案,接下来我们就详细了解下这种方案的实现。

ColorLabel的实现

所有的代码在这里,具体使用可以在我的项目中看到。

首先是定义默认颜色和QSS模板,模板用于后续的颜色设置:

var (
// 控制颜色的qss模板
colorStyle = "QLabel{color:%s;}"
// 默认颜色-黑色
defaultStyle = "QLabel{color:black;}"
)

其实空字符串""就表示使用系统自带样式,然而我这里为了统一就选用了黑色。

ColorLabel组件的定义,继承自QLabel,并保存自己的样式:

// ColorLabel 使用QSS显示彩色文字
type ColorLabel struct {
widgets.QLabel // color style sheet
defaultColor string
}

接着是构造函数,函数的功能在注释中写的比较清楚了,关键在于它调用的两个方法:

// NewColorLabelWithColor 生成colorlabel,设置default color为color
// color为空则设置为黑色
// color可以是颜色对应的名字,例如"black", "green"
// 也可以是16进制的RGB值,例如 #ffffff, #ff08ff, #000000
func NewColorLabelWithColor(text, color string) *ColorLabel {
l := NewColorLabel(nil, 0) l.SetDefaultColor(color)
l.SetDefaultColorText(text) return l
}

SetDefaultColor用于给ColorLabel设置默认的颜色,而SetDefaultColorText则和setText槽一样,给label设置文字,并使用默认指定的颜色显示,通过这两个方法我们可以处理绝大部分的使用场景,现在来看看它们的实现:

// SetDefaultColor 设置defaultColor
// color为""时设置为黑色
// 不会改变现有text内容的颜色
func (l *ColorLabel) SetDefaultColor(color string) {
if color == "" {
l.defaultColor = defaultStyle
return
} l.defaultColor = fmt.Sprintf(colorStyle, color)
} // SetDefaultColorText 设置新的text值,并使其显示设置的default color
func (l *ColorLabel) SetDefaultColorText(text string) {
l.SetText(text)
l.SetStyleSheet(l.defaultColor)
}

当color为空字符串时使用默认颜色,否则设置为color指定的颜色,color可以是颜色的名字/16进制值。值得一提的是,修改默认颜色并不会影响已经显示的文字,如果想改变已经显示的文字的颜色,需要使用ChangeColor

SetDefaultColorText则先使用SetText设置文字,随后添加QSS,因为这中间间隔相当短所以先添加QSS还是后添加不会有明显可见的区别,而且事件循环也会尽量将两次调用产生的重绘事件合并。

有时候我们也需要中途修改ColorLabel的颜色,或者颜色和文字一起修改,这时上面的方法就满足不了我们了,比如在这段代码里。

所以我们也实现了这些功能:

// ChangeColor 改变现有text的颜色
// 并且设置defaultColor为新的颜色
// color为""时设置为defaultStyle
func (l *ColorLabel) ChangeColor(color string) {
l.SetDefaultColor(color)
text := l.Text()
l.SetDefaultColorText(text)
} // SetColorText 用color显示新的text
// color为""时显示defaultStyle
func (l *ColorLabel) SetColorText(text, color string) {
var style string
if color == "" {
style = defaultStyle
} else {
style = fmt.Sprintf(colorStyle, color)
} l.SetText(text)
l.SetStyleSheet(style)
}

ChangeColor改变了已显示文字的颜色,并设置label默认的颜色为新的颜色。SetColorText则显示指定颜色的文字,不会影响label的默认设置。

有了这些方法,我们就能方便地设置文字的颜色了,而且因为我们继承自QLabel,所以可以使用QLabel提供的方法对文字的显示做更进一步的控制。

通过这个小例子,我们已经对QSS的实际使用有了较为具体的印象,在实际应用中QSS的强大功能将会为我们提供许多的便利,掌握QSS的使用会使你的开发技能更上一层楼。

欢迎大家提出意见,也欢迎大家关注我的项目

QSS的使用(二)——实现ColorLabel的更多相关文章

  1. Qss样式(二)

    Qss 其实就是一段文本,当然得按一定格式来写.下面请看Qss的语法格式: 选择器 { 属性1:值:属性2:值:--属性n:值:} 对应上篇文章的Qss样式: 现在我们可以来解释这段话的意思了: 对应 ...

  2. 统信DTK开发套件应用技术分享

    近年来,信创产业发展迅猛,国产软硬件适配的需求日益增加,但国内CPU架构种类繁多,导致大量的适配投入.同时,由于底层代码质量不同.代码实现风格不统一等问题,造成自研操作系统的应用开发门槛高,应用生态严 ...

  3. Qt样式表之二:QSS语法及常用样式

    一.简述 Qt样式表(以下统称QSS)的术语和语法规则几乎和CSS相同.如果你熟悉CSS,可以快速浏览以下内容.不熟悉的话可以先去W3School - CSS或者本人的CSS博客随笔简单了解一下. 在 ...

  4. Qt qss 使用

    1.在资源文件建立一个qss文件.如blue.qss 2. 调用 #include "mainwindow.h" #include <QApplication> #in ...

  5. Pyqt QSS简单的Ui美化

    什么是QSS QSS 是Qt StyleSheet 的简称,意思就是qt的样式表格,StyleSheet 可以像CSS一样的写样式.使页面美化跟代码层分开,利于维护. QSS的语法 同css一样,他也 ...

  6. QSS总结以及最近做的Qt项目

    什么是QSS QSS称为Qt Style Sheets也就是Qt样式表,它是Qt提供的一种用来自定义控件外观的机制.QSS大量参考了CSS的内容,只不过QSS的功能比CSS要弱很多,体现在选择器要少, ...

  7. Qt之QAbstractItemView视图项拖拽(二)

    一.需求说明 上一篇文章Qt之QAbstractItemView视图项拖拽(一)讲述了实现QAbstractItemView视图项拖拽的一种方式,是基于QDrag实现的,这个类是qt自己封装好了的,所 ...

  8. QT5 QSS

    设计Qt程序Ui的时候,可以像WEB端使用CSS一样,使用QSS,使页面美化跟代码层分开,利于维护. 过程如下: 1.建立文本文件,写入样式表内容,更改文件后缀名为qss: 2.在工程中新建资源文件* ...

  9. Qt Creator项目中使用qss

    近期学习qt .使用的编译器是qt creator ,学习过程中遇到的题就是 怎样将程序中将要用到的.qss 文件静态编译到.exe程序中,而不是在程序执行时动态加载.动态加载的最大问题在于一旦.qs ...

随机推荐

  1. 2018年10月OKR初步规划

    OKR(Objectives and Key Results)即目标+关键结果,是一套明确和跟踪目标及其完成情况的管理工具和方法 今天是十月的第一个工作日,也是我归零的第一天,受到一位前辈的启发,我决 ...

  2. .Net Core 部署 CentOs7+Nginx

    先爆图 由于是初学者,部署出来这个界面也不容易,此前第一步弄了个这个出来 动态的没问题,然后静态资源死活就是不出来,弄了两个小时没有结果,带着遗憾睡了个觉 试验1: server { listen ; ...

  3. linux虚机配置开发/Server环境全集

    linux虚机配置开发/Server环境全集 9. centos 升级githttp://www.cnblogs.com/grimm/p/5368777.htmla. 下载git2.2.1并将git添 ...

  4. swust oj 1013

    哈希表(开放定址法处理冲突) 1000(ms) 10000(kb) 2698 / 6177 采用除留余数法(H(key)=key %n)建立长度为n的哈希表,处理冲突用开放定址法的线性探测. 输入 第 ...

  5. excel写入操作

    字典列表类型数据写入excel. #导入xlwt库 import xlwt import os # 步骤1:获取excel文件的绝对路径 dirPath = os.path.join(os.getcw ...

  6. CUDA编程模型

    1. 典型的CUDA编程包括五个步骤: 分配GPU内存 从CPU内存中拷贝数据到GPU内存中 调用CUDA内核函数来完成指定的任务 将数据从GPU内存中拷贝回CPU内存中 释放GPU内存 *2. 数据 ...

  7. 关于HTTP协议,这一篇就够了

    HTTP简介 HTTP协议是Hyper Text Transfer Protocol(超文本传输协议)的缩写,是用于从万维网(WWW:World Wide Web )服务器传输超文本到本地浏览器的传送 ...

  8. Java面试题中常考的容易混淆的知识点区别

    以下是我收集的Java编程里各种区别,供Java学习爱好者参考,这些区别都是每次Java面试中常考的,大家好好掌握,如有失误请留言指出.想要获取Java详细全套学习资料请到上海尚学堂官网获取. 1.H ...

  9. [Swift]LeetCode157.用Read4来读取N个字符 $ Read N Characters Given Read4

    The API: int read4(char *buf) reads 4 characters at a time from a file.The return value is the actua ...

  10. [Swift]LeetCode769. 最多能完成排序的块 | Max Chunks To Make Sorted

    Given an array arr that is a permutation of [0, 1, ..., arr.length - 1], we split the array into som ...