将样式表应用于提升的小部件
Applying stylesheet to promoted widget
像这个 中的答案一样推广我的小部件后,建议我在这个特定小部件上应用我的样式表时遇到问题。请使用@eyllanesc 提供的答案作为工作代码。
我读过类似的问题,其中一些建议在 paintEvent 中处理这个?
我尝试在 Mainform class 和 UiLoader class 中应用此样式表,并将 widget.setStyleSheet 与 self.setStyleSheet 切换并将其放入 paintEvent。我也试过在 QWidget 之前没有点,并用 QObject 切换 QWidget。 None 这些尝试似乎奏效了。
widget.setStyleSheet("""
.QWidget{
border: 1px solid grey;
border-radius: 2px;
background-color: rgb(255, 255, 255);
}
""")
样式表在 Designer 中有效,但当我运行程序时样式表没有得到应用。
如果您希望小部件支持 QSS,则必须使用 QStyle 进行绘画,因为它在内部使用 QSS:
class Drawer(QtWidgets.QWidget):
def paintEvent(self, event):
opt = QtWidgets.QStyleOption()
opt.init(self)
qp = QtGui.QPainter(self)
self.style().drawPrimitive(QtWidgets.QStyle.PE_Widget, opt, qp, self)
self.drawGeometry(qp)
qp.end()
def drawGeometry(self, qp):
qp.setPen(QtGui.QPen(QtCore.Qt.green, 8, QtCore.Qt.DashLine))
qp.drawEllipse(40, 40, 400, 400)
您还必须使用以下 QSS:
# ...
loader = UiLoader()
self.ui_window = loader.load(ui_file)
ui_file.close()
self.ui_window.show()
self.ui_window.widget.setStyleSheet(
"""
QWidget{
border: 1px solid grey;
border-radius: 2px;
background-color: rgb(255, 255, 255);
}
"""
)
# ...
像这个
我读过类似的问题,其中一些建议在 paintEvent 中处理这个?
我尝试在 Mainform class 和 UiLoader class 中应用此样式表,并将 widget.setStyleSheet 与 self.setStyleSheet 切换并将其放入 paintEvent。我也试过在 QWidget 之前没有点,并用 QObject 切换 QWidget。 None 这些尝试似乎奏效了。
widget.setStyleSheet("""
.QWidget{
border: 1px solid grey;
border-radius: 2px;
background-color: rgb(255, 255, 255);
}
""")
样式表在 Designer 中有效,但当我运行程序时样式表没有得到应用。
如果您希望小部件支持 QSS,则必须使用 QStyle 进行绘画,因为它在内部使用 QSS:
class Drawer(QtWidgets.QWidget):
def paintEvent(self, event):
opt = QtWidgets.QStyleOption()
opt.init(self)
qp = QtGui.QPainter(self)
self.style().drawPrimitive(QtWidgets.QStyle.PE_Widget, opt, qp, self)
self.drawGeometry(qp)
qp.end()
def drawGeometry(self, qp):
qp.setPen(QtGui.QPen(QtCore.Qt.green, 8, QtCore.Qt.DashLine))
qp.drawEllipse(40, 40, 400, 400)
您还必须使用以下 QSS:
# ...
loader = UiLoader()
self.ui_window = loader.load(ui_file)
ui_file.close()
self.ui_window.show()
self.ui_window.widget.setStyleSheet(
"""
QWidget{
border: 1px solid grey;
border-radius: 2px;
background-color: rgb(255, 255, 255);
}
"""
)
# ...