PyQt5 – 当鼠标悬停在中间的复选框上时指标的背景图片

PyQt5 – 当鼠标悬停在中间的复选框上时指标的背景图片

在这篇文章中,我们将看到如何在复选框处于中间状态和鼠标悬停在它上面时,为复选框的指示器设置背景图像。默认情况下,复选框只有两种状态,但我们也可以在setTristate方法的帮助下建立第三种状态,即不检查或不检查的状态,它处于这两种状态之间,称为中间状态。

为了给中间状态的指示器添加背景图片,我们必须改变中间状态的指示器的样式表,当光标悬停在它上面时。下面是样式表的代码。

QCheckBox::indicator:indeterminate:hover
{
background-image : url(image.png);
}

以下是实施情况

# 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, 600, 400)
  
        # calling method
        self.UiComponents()
  
        # showing all the widgets
        self.show()
  
    # method for widgets
    def UiComponents(self):
        # creating the check-box
        checkbox = QCheckBox('Geek ?', self)
  
        # setting geometry of check box
        checkbox.setGeometry(200, 150, 100, 60)
  
        # setting tristate check box
        checkbox.setTristate(True)
  
        # changing size of indicator
        # adding background image to the indicator
        # when it is in intermediate state and when cursor hover it
        checkbox.setStyleSheet("QCheckBox::indicator"
                               "{"
                               "width : 60px;"
                               "height : 60px;"
                               "}"
                               "QCheckBox::indicator:indeterminate::hover"
                               "{"
                               "background-image : url(indicator_image.png);"
                               "}")
  
  
# create pyqt5 app
App = QApplication(sys.argv)
  
# create the instance of our Window
window = Window()
  
# start the app
sys.exit(App.exec())

Python教程

Java教程

Web教程

数据库教程

图形图像教程

大数据教程

开发工具教程

计算机教程