PyQt5 QCommandLinkButton – 结合检查和按下状态的背景色
在这篇文章中,我们将看到如何根据检查状态和悬停状态的结合,为可检查的QCommandLinkButton设置背景色。命令链接按钮是一种特殊类型的按钮,它具有按钮和单选按钮的特性。默认情况下,命令链接按钮没有额外的背景颜色,尽管我们可以在任何时候为它设置自定义的背景颜色。
我们可以在setCheckable方法的帮助下使命令链接按钮成为可检查的,基本上有两种检查状态,一种是检查状态,即当它处于按下的状态,另一种是未检查状态,即当它处于释放状态。
为了做到这一点,我们将为它设置样式表代码,为此我们使用命令链接按钮对象的setStyleSheet方法,下面是样式表代码
QCommandLinkButton::checked
{
background-color : lightgreen;
}
QCommandLinkButton::checked::pressed
{
background-color : yellow;
}
QCommandLinkButton::!checked
{
background-color : red;
}
QCommandLinkButton::!checked::pressed
{
background-color : pink;
}
以下是实施情况
# importing libraries
from PyQt5.QtWidgets import *
from PyQt5 import QtCore, QtGui
from PyQt5.QtGui import *
from PyQt5.QtCore import *
import sys
class Window(QMainWindow):
def __init__(self):
super().__init__()
# setting title
self.setWindowTitle("Python ")
# setting geometry
self.setGeometry(100, 100, 500, 400)
# calling method
self.UiComponents()
# showing all the widgets
self.show()
# method for components
def UiComponents(self):
# creating a command link button
cl_button = QCommandLinkButton("Press", self)
# making it chekable
cl_button.setCheckable(True)
# setting geometry
cl_button.setGeometry(150, 100, 200, 50)
# setting style sheet
# setting background color according to checked state
# adding background color for checked pressed state combine
cl_button.setStyleSheet("QCommandLinkButton::checked"
"{"
"border : 1px solid black;"
"background-color : lightgreen;"
"}"
"QCommandLinkButton::checked::pressed"
"{"
"border : 1px solid black;"
"background-color : yellow;"
"}"
"QCommandLinkButton::! checked"
"{"
"border : 1px solid black;"
"background-color : red;"
"}"
"QCommandLinkButton::! checked::pressed"
"{"
"border : 1px solid black;"
"background-color : pink;"
"}")
# create pyqt5 app
App = QApplication(sys.argv)
# create the instance of our Window
window = Window()
# start the app
sys.exit(App.exec())