使用PyQT5开发桌面应用--QSS的UI美化

        QSS(Qt Style Sheets)即 Qt 样式表,是用来定义控件外观的一种机制。QSS 大量参考了 CSS 的内容,和 CSS 的使用相类似,但功能要比 CSS 弱的多。主要体现为选择器少,可用的属性也少,并且不是所有的属性都可以应用在 PyQt 的控件上。但是 QSS 可以使页面和美化代码分开,利用维护,也给我们提供了页面美化的方案。

QSS的语法规则

        QSS 的语法规则几乎与 CSS 相同,如果对 CSS 比较了解的话,那么 QSS 的使用就不会有什么问题。

        QSS 样式由两部分组成,其中一部分是选择器,指定哪些控件会受到影响;另一部分是声明,指定哪些属性应该在控件上进行设置。声明部分是一系列的“属性:值”对,使用英文分号(;)分隔各个不同的属性对使用大括号({})将所有的声明包括在内

        示例:

QPushButton {
    color: red
}

        熟悉 CSS 的看到这样的表示方式应该不陌生,表示将 QPushButton 的前景色设置为红色。从 CSS 来看,这样理解没有什么问题,但是 QSS 这里是不一样的,QPushButton 表示的是PyQt中的按钮类,而非 CSS 中的标签含义,既然含义不一样了,那么上面的样式也多少会有区别。它代表的意义是:QPushButton 类及其子类的所有实例的前景色是红色。需要注意的是,凡是继承 QPushButton 的子类都会受到影响

QSS选择器类型

        QSS选择器有如下几种类型:

  1. 通配选择器:*,匹配所有的控件。
  2. 类型选择器:写入需要匹配的控件类型名称,如:QPushButton,匹配所有的 QPushButton 类及其子类的实例。
  3. 属性选择器:控件类型[属性名=属性值],如:QPushButton[name="btn"],匹配所有 name 属性是 btn 的 QPushButton 实例。这里的属性是可以自定义的,这与HTML自定义属性的概念一样,不一定非要用类本身具有的属性。
  4. 类选择器:.控件类型,如:.QPushButton,匹配所有 QPushButton 实例,但是并不匹配其子类。
  5. ID选择器:#对象名称,如:#btn,匹配所有 ID 为 btn 的控件,这里的 ID 实际上是控件的 objectName 的值,这是需要注意的地方。
  6. 后代选择器:控件类型1 控件类型2,如:QDialog QPushButton,匹配所有 QDialog 容器中的 QPushButton,不管是直接的还是间接的。
  7. 子选择器:控件类型1 > 控件类型2,如:QDialog > QPushButton,匹配所有的 QDialog 容器中的 QPushButton,只包括直接的。

        以上所有的选择器可以联合使用,并且支持一次设置多种类型选择器,用英文逗号隔开,这与 CSS 的使用基本上是一样的。

在代码中设置QSS

        上面完成了对QSS常用内容的说明,接下来看一下如何在代码中设置QSS。使用的方式也很简单,调用 QWidget 的成员函数 setStyleSheet(QSS格式字符串) 即可完成设置。

        代码示例:

import typing
from PyQt5 import QtCore
from PyQt5.QtWidgets import *
import sys

from PyQt5.QtWidgets import QWidget

# 使用代码方式设计页面,以便代码演示
class QssDemo(QWidget):
    def __init__(self):
        super().__init__()

        # 创建 QPushButton 实例
        btn = QPushButton(self)
        # 设置按钮显示文字
        btn.setText("QSS展示按钮")
        # 设置 objectName 为 btn
        btn.setObjectName("btn")

        self.setWindowTitle("QSS样式使用示例")


if __name__ == "__main__":
    app = QApplication(sys.argv)
    win = QssDemo()

    # QSS样式字符串
    qssStr = """
        #btn {
            width: 200;
            height: 100;
            color: red;
        }
    """
    win.setStyleSheet(qssStr)

    win.show()
    sys.exit(app.exec_())

 

        以上的代码示例应该不难理解,不过这个代码有些问题,问题是我们把QSS的样式以编码的方式写在了代码中,不方便以后的维护。

        发现问题,解决问题。可以将QSS样式内容编写进以后缀名 .qss 命名的文件,然后再在程序中读取加载该文件内容就可以完成代码和QSS样式相分离的目的。

        对上面示例代码进行改造。新建 test.qss 样式文件,将上面示例代码中的 QSS 内容放入该文件中。

#btn {
    width: 200;
    height: 100;
    color: red;
}

        接下来将上面示例代码入口处设置QSS样式的方式改为从QSS文件加载。此处仅展示不一样的代码部分。

if __name__ == "__main__":
    app = QApplication(sys.argv)
    win = QssDemo()

    # 加载 QSS 样式文件 test.qss
    with open("test.qss", "r") as f:
        qssStr = f.read()
        win.setStyleSheet(qssStr)

    win.show()
    sys.exit(app.exec_())

        这里只是对QSS做了一个简短的介绍,具体内容可以查看官方文档:Qt Style Sheets — Qt for Python

  • 11
    点赞
  • 16
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: PyQt5Python编程语言的一种GUI库,用于创建桌面应用程序。它是由Riverbank Computing开发的,为开发者提供了丰富的GUI元素和功能,使他们能够轻松地构建各种用户界面。 而PyQt5-sip是PyQt5的一部分,是一个用于生成Python绑定代码的代码生成器。它将C++头文件转换为Python模块,使开发者能够在Python使用C++框架和库。PyQt5-sip负责将QObject、QEvent等类和对象转换为Python可调用的代码。 PyQt5PyQt5-sip之间的关系可以简单地理解为:PyQt5-sip是PyQt5的一个重要组成部分,它提供了与C++代码的交互能力,使得PyQt5能够与底层的Qt库进行通信。在安装PyQt5时,PyQt5-sip会自动包含在内,因此我们不需要单独安装或管理PyQt5-sip。 对于开发者而言,了解PyQt5PyQt5-sip的版本非常重要。这是因为PyQt5PyQt5-sip的版本必须相互兼容,以确保代码能够正确地运行。如果您使用PyQt5版本与PyQt5-sip不兼容,可能导致一些错误或功能失效。因此,在使用PyQt5时,我们需要确保选择合适的PyQt5-sip版本与之配套。 总结来说,PyQt5是一款强大的GUI库,而PyQt5-sip是PyQt5的重要组成部分,用于生成与C++代码交互的Python绑定代码。了解并选择合适的PyQt5PyQt5-sip版本对于确保顺利开发和运行PyQt5应用程序是必要的。 ### 回答2: PyQt5PyQt5-sip 是两个与 Python 语言结合使用的库。这两个库的版本是相互关联的。 PyQt5 是基于 Qt 库的 Python 封装,可以用于开发图形界面应用程序。它提供了丰富的 GUI 组件和功能,可以通过 Python 代码来创建和控制界面。 PyQt5-sip 是 PyQt5 的依赖库,它是用于处理 Python 对象和 Qt 对象之间的转换和通信的工具。它实际上是 PyQt5 的一部分,负责生成包装 Qt 类的 Python 类的代码。 这两个库的版本是相关的,因为 PyQt5-sip 的版本必须与 PyQt5 的版本相匹配。如果版本不匹配,可能会导致库之间的不兼容性和错误。因此,在使用 PyQt5 时,你需要根据 PyQt5 的版本来选择相应的 PyQt5-sip 版本。 通常,你可以通过以下命令来安装最新版本的 PyQt5PyQt5-sip: ``` pip install PyQt5 ``` 然后,PyQt5-sip 会自动安装为 PyQt5 的依赖项。 总的来说,PyQt5PyQt5-sip 是用于 Python GUI 开发的重要工具。在使用时需要注意版本匹配,以确保两者能够正常工作。 ### 回答3: PyQt5是一个Python绑定的Qt库,它允许开发者通过Python语言来开发跨平台的图形用户界面(GUI应用程序。 而pyqt5-sip是PyQt5的一个SIP模块,用于将C++库和Python语言进行交互。它是一个必需的依赖项,需要与PyQt5配套使用PyQt5-sip是由Riverbank Computing提供的一款工具,它通过SIP(一个Python/C++通信框架)来实现C++和Python的互操作性。SIP工具将C++代码转换成Python代码,使得开发人员可以在Python中直接调用C++代码和库。 在使用PyQt5时,我们需要安装和配置PyQt5pyqt5-sip两个软件包。PyQt5提供了丰富的Qt类和方法,用于创建各种类型的GUI应用程序。而pyqt5-sip则是在PyQt5中作为连接器的角色,它将C++对象转换为Python对象,并使得Python能够直接调用C++代码和库,实现了二者之间的桥梁。 需要注意的是,PyQt5pyqt5-sip的版本需要匹配,才能保证二者的兼容性。因此,在安装PyQt5pyqt5-sip时,应该选择合适的版本,并确保它们能够正确地配合使用。 总的来说,PyQt5是一个功能强大的库,用于开发Python GUI应用程序,而pyqt5-sip是其所依赖的一个模块,用于实现C++和Python之间的互操作性。它们共同工作,帮助我们使用Python语言开发出跨平台的GUI应用程序。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值