pyqt:如何将样式表应用于自定义窗口小部件

时间:2014-03-19 11:28:59

标签: python pyqt qtstylesheets

# -*- coding: utf-8 -*-

import sys
from PyQt4.QtGui import *  
from PyQt4.QtCore import * 

class MainWindow(QWidget):
    def __init__(self):
        super(MainWindow, self).__init__()

        self.setFixedWidth(200)
        self.setFixedHeight(200)

        stylesheet = \
            ".QWidget {\n" \
            + "border: 20px solid black;\n" \
            + "border-radius: 4px;\n" \
            + "background-color: rgb(255, 255, 255);\n" \
            + "}"
        self.setStyleSheet(stylesheet)

if __name__ == '__main__':

    app = QApplication(sys.argv)
    main = MainWindow()
    main.show()
    sys.exit(app.exec_())

我想为带有样式表的自定义小部件添加边框,但样式表似乎不起作用,有什么不对吗?

2 个答案:

答案 0 :(得分:20)

首先:在示例中添加一个实际的小部件:

    self.widget = QWidget(self)
    layout = QVBoxLayout(self)
    layout.addWidget(self.widget)

其次:帮自己一个忙,并使用三引号:

    self.widget.setStyleSheet("""
        .QWidget {
            border: 20px solid black;
            border-radius: 10px;
            background-color: rgb(255, 255, 255);
            }
        """)

注意:示例中的点选择器是多余的。它的作用是指定只选择QWidget本身的实例,而不是QWidget的子类。请参阅Qt文档中的StyleSheet Syntax指南。

答案 1 :(得分:1)

在您的项目文件夹中,添加一个基本的CSS文件mystylesheet.css。像atom这样的多语言编辑器最适合这类事情。如果将其命名为css文件,则语法突出显示将正常工作。

然后放点,qt知道你的意思。

CSS:
QWidget {
    border: 20px solid black;
    border-radius: 10px;
    background-color: rgb(255, 255, 255);
}

Python:
anyQelement.setStyleSheet(open('mystylesheet.css').read())