问题描述
我想绘制一个 QPushButton
(可点击等),但让它看起来像一个 QLabel
。 (另一种理解方式是我想要一个可点击的标签,即行为类似于按钮的标签,但这似乎更难。)
我试过 button.setStyleSheet("QLabel")
,没有用。
有没有办法告诉按钮使用另一个样式类?还是“窃取”QLabel
的风格?
如果可能,我希望避免重新定义整个样式(我不拥有样式表,Qt 嵌入在第三方应用程序中),除非这是微不足道的。
编辑:我最终使用了@musicamante 的样式表解决方案,我添加了 text-align: left
(按钮居中,标签不是)和 :hover/:pressed
颜色(青色/蓝色看起来像程序员艺术,但达到目的:):
QPushButton {
border: none;
background: transparent;
text-align: left;
color: palette(window-text);
}
QPushButton:hover {
color: cyan;
}
QPushButton:pressed {
color: blue;
}
解决方法
通常不建议将按钮样式设置为标签,因为它不会清除其状态,尤其是当鼠标按钮在按钮矩形之外被按下和释放时。
无论如何,将 border
属性设置为 none
就足够了,这也将删除背景。为了安全和一致,您可以使背景透明(某些样式可能会覆盖它)并确保使用调色板的 WindowText
颜色角色(而不是 ButtonText
角色):>
button.setStyleSheet("""
border: none;
color: palette(window-text);
background: transparent;
""")
不过,制作一个可点击的标签并不难,它的好处是允许使用富文本内容,这是 QPushButton 无法做到的。
class ClickableLabel(QLabel):
clicked = Signal()
def mousePressEvent(self,event):
super(ClickableLabel,self).mousePressEvent(event)
if event.button() == Qt.LeftButton:
self.clicked.emit()
或者,为了提供与按钮行为的一致性(如上所述,如果在按钮矩形的边界内释放鼠标按钮,则“单击”被认为是有效的):
class ClickableLabel(QLabel):
clicked = Signal()
def mouseReleaseEvent(self,self).mouseReleaseEvent(self,event)
if event.button() == Qt.LeftButton and event.pos() in self.rect():
self.clicked.emit()
,
你可以创建一个自定义的QLabel,先公开继承一个QLabel,然后重载 void mouseReleaseEvent(QMouseEvent *e)
void mouseReleaseEvent(QMouseEvent *e){
if(e.button == Qt::LeftButton){
//emit a signal or you want to do when the label are clicked
}
}