百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 技术文章 > 正文

Python入坑系列-pyside6桌面编程之QColor添加色彩彰显个性

myzbx 2024-12-04 13:58 13 浏览

通过本文章,你可以掌握以下内容:

  1. Pyside6 Color颜色模型
  2. Pyside6 Color色系介绍
  3. Pyside6更换系统主题

1、Pyside6 Color颜色模型

颜色通常以RGB(红色、绿色和蓝色)分量的形式指定,但也可以以HSV(色调、饱和度和亮度)和CMYK(青色、品红、黄色和黑色)分量的形式指定。此外,还可以使用颜色名称来指定颜色。颜色名称可以是SVG 1.0颜色名称中的任何一个

QColor构造函数基于RGB值创建颜色。要基于HSV或CMYK值创建QColor,分别使用toHsv()和toCmyk()函数。这些函数返回使用所需格式的颜色副本。此外,静态函数fromRgb()、fromHsv()和fromCmyk()可以从指定的值创建颜色。或者,可以使用convertTo()函数将颜色转换为任一三种格式(返回所需格式的颜色副本),或使用setRgb()、setHsv()和setCmyk()函数改变此颜色的格式。spec()函数指明颜色是如何被指定的。

可以通过向fromString()函数传递一个RGB字符串(如“#112233”)、一个ARGB字符串(如“#ff112233”)或一个颜色名称(如“blue”)来设置颜色。颜色名称取自SVG 1.0颜色名称。name()函数以“#000000”的格式返回颜色的名称。也可以使用setRgb()、setHsv()和setCmyk()设置颜色。要获取更亮或更暗的颜色,分别使用lighter()和darker()函数。

isValid()函数指示QColor是否完全合法。例如,RGB值超出范围的RGB颜色是非法的。出于性能原因,QColor大多忽略非法颜色,因此,使用无效颜色的结果是未定义的。颜色组件可以单独检索,例如使用red()、hue()和cyan()。

颜色组件的值也可以一次性使用getRgb()、getHsv()和getCmyk()函数检索。使用RGB颜色模型,颜色组件还可以通过rgb()访问。

有几个相关的非成员函数:QRgb是代表RGB值三元组(r, g, b)的unsigned int的类型定义。注意,它也可以保存alpha通道的值(更多信息,请参见Alpha-Blended Drawing部分)。qRed()、qBlue()和qGreen()函数返回给定QRgb值的相应组件,而qRgb()和qRgba()函数基于给定的组件值创建并返回QRgb三元组。最后,qAlpha()函数返回提供的QRgb的alpha组件,qGray()函数基于给定值计算并返回一个灰度值。QColor是平台和设备独立的。QColormap类将颜色映射到硬件上。

预定义颜色

命名空间中有 20 个预定义QColor对象QColorConstants,包括黑色、白色、主要和次要颜色、这些颜色的较暗版本,以及三种灰度。此外,QColorConstants.Svg命名空间为标准SVG颜色关键字名称定义了QColor对象。

QColorConstants.Color0、QColorConstants.Color1和QColorConstants.Transparent颜色用于特殊目的。QColorConstants.Color0(零像素值)和QColorConstants.Color1(非零像素值)是在QBitmaps中绘图的特殊颜色。使用QColorConstants.Color0绘制将位图位设置为0(透明;即背景),而使用QColorConstants.Color1绘制将位设置为1(不透明;即前景)。QColorConstants.Transparent用于指示透明像素。使用此值绘制时,将使用适合正在使用的底层像素格式的像素值。

HSV 颜色模型

RGB 模型是面向硬件的。它的表现接近大多数显示器的显示。相比之下,HSV 以更适合人类对颜色感知的方式表示颜色。例如,“强于”、“暗于”和“相反”的关系在 HSV 中很容易表达,但在 RGB 中很难表达。

HSV 与 RGB 一样,具有三个组成部分

  • H(色调),如果颜色是彩色(不是灰色),则在 0 到 359 范围内;如果颜色是灰色,则毫无意义。它代表大多数人熟悉的色轮上的度数。红色为 0(度),绿色为 120,蓝色为 240。
  • S代表饱和度,范围是0到255,它越大,颜色越强。浅灰色的饱和度接近 0;非常强烈的颜色饱和度接近 255。
  • V 代表颜色,范围为 0 到 255,代表颜色的明度或亮度。 0 为黑色; 255 尽可能远离黑色。

2、Pyside6 Color色系介绍

色彩是视觉设计的重要组成部分,它不仅能影响美观性,还能影响情绪和行为。由于桌面程序默认组件的色彩比较单一,需要开发通过了解色彩系统给组件配色,给用户带来视觉冲击。

下面是自定义颜色标签,部分示例会使用到该类

import re
from PySide6.QtCore import Qt
from PySide6.QtGui import QPalette, QColor
from PySide6.QtWidgets import QLabel
class ColorLable(QLabel):
    def __init__(self, text, color=None, fontcolor="white", align=Qt.AlignCenter):
        """接收color参数为:按颜色名称(如 "red")、十六进制颜色代码(如 "#000000")以及RGB值(如 rgb(83, 168, 255))"""
        super(ColorLable, self).__init__()
        self.setAlignment(align)
        self.setStyleSheet(f"color:{fontcolor}")
        self.setAutoFillBackground(True)
        if color is None:
            color = text
        rgb_match = re.match(r'rgb\((\d+),\s*(\d+),\s*(\d+)\)', color)
        if rgb_match:
            r, g, b = map(int, rgb_match.groups())
            qcolor = QColor(r, g, b)
        else:
            qcolor = QColor(color)
        r, g, b, _ = qcolor.getRgb()
        hex_str_upper = qcolor.name().upper()
        if color is text:
            self.setText(f"{color}<br>rgb({r}, {g}, {b})<br>{hex_str_upper}")
        elif text == "":
            self.setText(f"rgb({r}, {g}, {b})<br>{hex_str_upper}")
        else:
            self.setText(f"{color}<br>rgb({r}, {g}, {b})<br>{hex_str_upper}")
        palette = self.palette()
        palette.setColor(QPalette.Window, qcolor)
        self.setPalette(palette)

原色

原色是不能通过混合其他颜色来创建的颜色。在传统的色彩理论中,原色包括红色、黄色和蓝色。在光的颜色混合(如屏幕显示)中,原色被认为是红色、绿色和蓝色(RGB)

示例代码如下:

import re
from PySide6.QtCore import Qt
from PySide6.QtGui import QPalette, QColor
from PySide6.QtWidgets import QLabel

class ColorLable(QLabel):
    def __init__(self, text, color=None, fontcolor="white", align=Qt.AlignCenter):
        """接收color参数为:按颜色名称(如 "red")、十六进制颜色代码(如 "#000000")以及RGB值(如 rgb(83, 168, 255))"""
        super(ColorLable, self).__init__()
        self.setAlignment(align)
        self.setStyleSheet(f"color:{fontcolor}")
        self.setAutoFillBackground(True)
        if color is None:
            color = text
        rgb_match = re.match(r'rgb\((\d+),\s*(\d+),\s*(\d+)\)', color)
        if rgb_match:
            r, g, b = map(int, rgb_match.groups())
            qcolor = QColor(r, g, b)
        else:
            qcolor = QColor(color)
        r, g, b, _ = qcolor.getRgb()
        hex_str_upper = qcolor.name().upper()
        if color is text:
            self.setText(f"{color}<br>rgb({r}, {g}, {b})<br>{hex_str_upper}")
        elif text == "":
            self.setText(f"rgb({r}, {g}, {b})<br>{hex_str_upper}")
        else:
            self.setText(f"{text}<br>rgb({r}, {g}, {b})<br>{hex_str_upper}")
        palette = self.palette()
        palette.setColor(QPalette.Window, qcolor)
        self.setPalette(palette)

主色

在视觉设计中指的是在一幅画面、设计作品或空间中占据主导地位的颜色。这种颜色通常是最引人注目的,能够影响整体的视觉效果和情感氛围。选择合适的主色调对于确保设计的协调性和传达正确的信息至关重要。

示例代码如下:

import sys
from PySide6.QtWidgets import *
from color.colorlable import ColorLable
class MainWindow(QMainWindow):
    def __init__(self):
        super(MainWindow, self).__init__()
        self.setWindowTitle("QColor之主色-蓝色系")
        self.setMinimumSize(700, 500)
        vboxlayout = QVBoxLayout()
        hboxlayout = QHBoxLayout();
        vboxlayout.addWidget(ColorLable("Brand Color", "#409EFF","black"))
        hboxlayout.addWidget(ColorLable("","rgb(83, 168, 255)","black"))
        hboxlayout.addWidget(ColorLable("", "rgb(102, 177, 255)","black"))
        hboxlayout.addWidget(ColorLable("", "rgb(121, 187, 255)","black"))
        hboxlayout.addWidget(ColorLable("", "rgb(140, 197, 255)","black"))
        hboxlayout.addWidget(ColorLable("", "rgb(160, 207, 255)","black"))
        hboxlayout.addWidget(ColorLable("", "rgb(179, 216, 255)","black"))
        hboxlayout.addWidget(ColorLable("", "rgb(198, 226, 255)","black"))
        hboxlayout.addWidget(ColorLable("", "rgb(217, 236, 255)","black"))
        vboxlayout.addLayout(hboxlayout)
        widget = QWidget()
        widget.setLayout(vboxlayout)
        self.setCentralWidget(widget)
if __name__ == '__main__':
    app = QApplication(sys.argv)
    window = MainWindow()
    window.show()
    app.exec()

暖色

温暖色系主要包括红色、橙色、黄色及其衍生色调,这些颜色通常会让人联想到阳光、火焰和暖光等,能够给人带来温暖、舒适和活力的感觉。在视觉设计、艺术和室内装饰中,温暖色系经常被用来创造亲切、欢快的氛围

示例代码如下:

import sys
from PySide6.QtWidgets import *
from color.colorlable import ColorLable
class MainWindow(QMainWindow):
    def __init__(self):
        super(MainWindow, self).__init__()
        self.setWindowTitle("QColor之暖色系")
        self.setMinimumSize(700, 500)
        layout = QHBoxLayout()
        layout.addWidget(ColorLable("red"))
        layout.addWidget(ColorLable("orange"))
        layout.addWidget(ColorLable("yellow"))
        widget = QWidget()
        widget.setLayout(layout)
        self.setCentralWidget(widget)
if __name__ == '__main__':
    app = QApplication(sys.argv)
    window = MainWindow()
    window.show()
    app.exec()

辅助色

是色轮上互为对立的颜色,它们在视觉上形成鲜明的对比,能够相互强化对方的鲜艳度和视觉冲击力。当这些颜色组合在一起时,可以创造出极具吸引力和动态的视觉效果,除了主色外的场景色,需要在不同的场景中使用(例如危险色表示危险的操作)

示例代码如下:

import sys
from PySide6.QtWidgets import *
from color.colorlable import ColorLable
class MainWindow(QMainWindow):
    def __init__(self):
        super(MainWindow, self).__init__()
        self.setWindowTitle("QColor之辅助色")
        self.setMinimumSize(700, 500)
        mainlayout = QHBoxLayout()
        vboxsuccess = QVBoxLayout()
        hboxsuccess = QHBoxLayout()
        vboxsuccess.addWidget(ColorLable("Success", "#67C23A","black"))
        hboxsuccess.addWidget(ColorLable("","rgb(225, 243, 216)","black"))
        hboxsuccess.addWidget(ColorLable("", "rgb(240, 249, 235)","black"))
        vboxsuccess.addLayout(hboxsuccess)
        mainlayout.addLayout(vboxsuccess)
        vboxwarn = QVBoxLayout()
        hboxwarn = QHBoxLayout()
        vboxwarn.addWidget(ColorLable("Warning", "#E6A23C", "black"))
        hboxwarn.addWidget(ColorLable("", "rgb(250, 236, 216)", "black"))
        hboxwarn.addWidget(ColorLable("", "rgb(253, 246, 236)", "black"))
        vboxwarn.addLayout(hboxwarn)
        mainlayout.addLayout(vboxwarn)
        vboxdanger = QVBoxLayout()
        hboxdanger = QHBoxLayout()
        vboxdanger.addWidget(ColorLable("Danger", "#F56C6C", "black"))
        hboxdanger.addWidget(ColorLable("", "rgb(253, 226, 226)", "black"))
        hboxdanger.addWidget(ColorLable("", "rgb(254, 240, 240)", "black"))
        vboxdanger.addLayout(hboxdanger)
        mainlayout.addLayout(vboxdanger)
        vboxinfo = QVBoxLayout()
        hboxinfo = QHBoxLayout()
        vboxinfo.addWidget(ColorLable("Info", "#909399", "black"))
        hboxinfo.addWidget(ColorLable("", "rgb(233, 233, 235)", "black"))
        hboxinfo.addWidget(ColorLable("", "rgb(244, 244, 245)", "black"))
        vboxinfo.addLayout(hboxinfo)
        mainlayout.addLayout(vboxinfo)
        widget = QWidget()
        widget.setLayout(mainlayout)
        self.setCentralWidget(widget)
if __name__ == '__main__':
    app = QApplication(sys.argv)
    window = MainWindow()
    window.show()
    app.exec()

中性色

中性色指的是不包含或几乎不包含色相的颜色,它们在色彩搭配中起到平衡和稳定的作用。中性色包括黑色、白色、灰色,以及不同深浅的棕色和米色。这些颜色因其灵活性和适应性,在设计和艺术领域中被广泛应用。常用于文本、背景和边框颜色,通过运用不同的中性色,来表现层次结构。

示例代码如下:

import sys
from PySide6.QtWidgets import *
from color.colorlable import ColorLable
class MainWindow(QMainWindow):
    def __init__(self):
        super(MainWindow, self).__init__()
        self.setWindowTitle("QColor之辅助色")
        self.setMinimumSize(700, 500)
        mainlayout = QHBoxLayout()
        layout1 = QVBoxLayout()
        layout1.addWidget(ColorLable("主要文字", "#303133"))
        layout1.addWidget(ColorLable("常规文字", "#606266"))
        layout1.addWidget(ColorLable("次要文字", "#909399"))
        layout1.addWidget(ColorLable("占位文字", "#C0C4CC"))
        mainlayout.addLayout(layout1)
        layout2 = QVBoxLayout()
        layout2.addWidget(ColorLable("一级边框", "#DCDFE6", "black"))
        layout2.addWidget(ColorLable("二级边框", "#E4E7ED", "black"))
        layout2.addWidget(ColorLable("三级边框", "#EBEEF5", "black"))
        layout2.addWidget(ColorLable("四级边框", "#F2F6FC", "black"))
        mainlayout.addLayout(layout2)
        layout3 = QVBoxLayout()
        layout3.addWidget(ColorLable("基础黑色", "#000000"))
        layout3.addWidget(ColorLable("基础白色", "#FFFFFF", "black"))
        layout3.addWidget(ColorLable("透明", "Transparent", "black"))
        mainlayout.addLayout(layout3)
        widget = QWidget()
        widget.setLayout(mainlayout)
        self.setCentralWidget(widget)
if __name__ == '__main__':
    app = QApplication(sys.argv)
    window = MainWindow()
    window.show()
    app.exec()

颜色选择器

Pyside6可以通过QColorDialog.getColor(),直接打开颜色选择器

import sys
from PySide6.QtWidgets import QApplication, QColorDialog
if __name__ == '__main__':
    app = QApplication(sys.argv)
    color = QColorDialog.getColor()
    sys.exit(app.exec())

SVG颜色码表

3、更换系统主题

在PySide6与html页面实现主题切换类似,通过更换全局样式表实现,具体步骤如下:

1.定义样式表:为每个主题创建一个样式表文件,或者在一个大的样式表文件中为不同的主题定义不同的部分。

2. 加载样式表:在应用程序启动时,根据用户的主题选择加载相应的样式表。这可以通过读取一个配置文件、数据库或者其他持久化存储的方式来确定用户上次选择的主题。

3. 应用样式表:使用QApplication的setStyleSheet方法应用加载的样式表。这将影响应用程序中所有控件的外观。

4. 切换主题:提供一个界面元素(如菜单项、按钮等)供用户选择主题。当用户选择一个新主题时,重新加载对应的样式表并应用它。

5. 保存用户选择:将用户的主题选择保存到配置文件、数据库或其他持久化存储中,以便下次启动应用程序时能够恢复用户的选择。

示例代码如下:

import sys
from PySide6.QtWidgets import QApplication, QMainWindow, QPushButton, QVBoxLayout, QWidget
class MainWindow(QMainWindow):
    def __init__(self):
        super().__init__()
        self.setWindowTitle("QColor之主题切换")
        self.setGeometry(100, 100, 400, 300)
        # 创建中心窗口和布局
        centralWidget = QWidget()
        self.setCentralWidget(centralWidget)
        layout = QVBoxLayout(centralWidget)
        # 创建切换主题的按钮
        self.toggleThemeBtn = QPushButton("切换")
        self.toggleThemeBtn.clicked.connect(self.toggleTheme)
        layout.addWidget(self.toggleThemeBtn)
        # 默认主题
        self.currentTheme = "light"

    def toggleTheme(self):
        if self.currentTheme == "light":
            self.applyDarkTheme()
            self.currentTheme = "dark"
        else:
            self.applyLightTheme()
            self.currentTheme = "light"
    def applyLightTheme(self):
        self.setStyleSheet("""
            QPushButton {background-color: white;color: black;}
            QMainWindow {background-color: lightgray;}
        """)
    def applyDarkTheme(self):
        self.setStyleSheet("""
            QPushButton {background-color: black;color: white;}
            QMainWindow {background-color: darkgray;}
        """)
if __name__ == "__main__":
    app = QApplication(sys.argv)
    window = MainWindow()
    window.show()
    sys.exit(app.exec())

相关推荐

Web 界面开发指南,持续更新(web界面开发工具)

最近看到了一份非常精简但很实用的《Web界面开发指南》,其中仅有4页,却详细阐述了前端交互体验的关键要点。这份指南的思路和方法相当于一个最佳实践,比许多冗长的内容介绍更易于理解。实际上即使没有太...

矢量图标LOGO绘制教程(二):短信应用

前言本次教程使用软件为:InkscapeInkscape是一款功能强大的免费设计工具。无论您是插画家、设计师、网页设计师,还是只是需要创建一些矢量图像的人,Inkscape都适合您!它具有以下功能...

Deepseek生成图片的几个方法,示例模板附上

针对DeepSeek生成图片场景设计的原创提示语模板及示例,结合了多步引导、参数化要求和第三方工具协同策略,可适配不同设计需求:一、SVG代码生成法(适用技术型用户)提示语结构:请将下方文本内容转化为...

这个质量超高的PPT背景生成器,开发者居然才12岁,来自加拿大

很多人在上手PPT设计的时候,最头疼的可能就是背景的问题了,想找一些既能丰富视觉层次,又不影响文字呈现的背景图:但是又不知道,该去哪里找?或者找到了能不能商用:其实,你可以用一些免费的,背景生成器做出...

免费好用还高级!3个必须知道的设计网站,让你的PPT好看10倍

哈喽,大家早上好鸭~好久不见,我是三石,今天我又来进行PPT技巧分享啦~诶,这不前几天编辑部的萌萌就来找我约稿,说小叶子们对于神器网站的呼声很高,问我能不能写一篇文章汇总一下,我二话没说就答应了。常言...

前端必备!干货满满的前端周刊(第三期)

前端周刊是一份专为前端从业人员,以及对前端、设计领域感兴趣的朋友们打造的技术周刊。程小狮会精选出前端、设计领域近期相关的资讯、热点以及技术干货,与大家一同分享。前端周刊专注于前端领域技术分享。希望这份...

筛选了100个配色工具后,我挑出了这25个

研究主题:提升色彩感知的配色工具研究对象:配色工具UI设计中,颜色几乎是最先被感知到的设计元素,好的色彩感知是成为一个优秀的设计师的基础,配色工具层出不穷,辞典酱在筛选了100多种配色工具后,精选了...

前端开发-SVG从入门到实战(前端swc)

SVG(可缩放矢量图形)是前端开发中不可或缺的技术,它既能实现高清无损缩放,又能通过代码动态控制,完美适配复杂交互场景。本文将从基础到进阶,带你快速掌握SVG的核心技巧。SVG的核心优势矢量图形,无限...

一场演唱会,揭开了那英的“真面目”,怪不得被宋祖德喊话封杀

还在为运气发愁?别担心,关注我,好运连连,财运亨通!那英,大家都知道,这是个响当当的名字,作为华语乐坛的“天后”,她的歌声陪伴了无数人的青春,可最近这场在澳门的演唱会,可把她的热度压得有点低,甚至让人...

【消防宣传月】居家遇初火千万别着急!这就教你怎么灭→

“消防安全大家谈”“119”消防宣传月策划持续推新这次带来的是趣味互动科普第四弹!渝仔消妹精心设计了SVG互动式消防知识主题秀以屏幕互动的方式将知识点一步步鲜活地呈现给大家家庭初起火灾如何扑救家是温馨...

Winform革命:如何用aardio版AntdUI打造Web级美观界面?

大家好,我是风行者,一个拥有15年开发经验和教学经验的80后嘿,Winform开发者们!你是否还在为那些老掉牙的界面设计头疼?是不是每次看到那些光鲜亮丽的Web应用,心里就痒痒的,想着:“要是我的应用...

FastReport.Net v2016.6发布,添加打印对话框等新功能

新版本的FastReport添加了报表对象:PolyLineObject-中断曲线,PolygonObject-填充密闭多边形。除此之外,用户也能够通过移动、添加或者去除定位点来编辑已经准备好的对象...

高效办公,你值得拥有之原型工具AXURE篇

简介AxureRP是美国AxureSoftwareSolution公司旗舰产品,是一个专业的快速原型设计工具,让负责定义需求和规格、设计功能和界面的专家能够快速创建应用软件或Web网站的线框图...

300 多行代码搞定微信 8.0 的「炸」「裂」特效!

微信8.0更新的一大特色就是支持动画表情,如果发送的消息只有一个内置的表情图标,这个表情会有一段简单的动画,一些特殊的表情还有全屏特效,例如烟花表情有全屏放烟花的特效,炸弹表情有爆炸动画并且消息和...

基于Vue的yyds图片编辑器(vue editormd)

一、项目简介基于Vue的yyds图片编辑器二、实现功能支持复制粘贴支持自定义字体支持自定义素材支持自定义设计模板支持多元素垂直、水平对齐方式支持拆分/组合组合支持保存为SVG、PNG、JSON文件支持...