PyQt5 – 鼠标悬停时将皮肤设置为不可编辑的关闭状态组合框
在本文中,我们将看到如何在不可编辑的组合框处于关闭状态时设置皮肤,当鼠标悬停在它上面时,皮肤基本上是背景图像,但皮肤会根据组合框的大小调整其大小。 OFF 状态是当列表视图(项目视图)未打开时,使用setEditable
方法使组合框可编辑。皮肤只会出现组合框是不可编辑的,它处于开启状态并且光标在它上面
为此,我们必须更改组合框的样式表代码,下面是样式表代码
QComboBox::!editable:!on:hover
{
border-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 a check-able combo box object
self.combo_box = QComboBox(self)
# setting geometry of combo box
self.combo_box.setGeometry(200, 150, 200, 80)
# making combo box editable
# self.combo_box.setEditable(True)
# geek list
geek_list = ["Sayian", "Super Sayian", "Super Sayian 2", "Super Sayian B"]
# adding list of items to combo box
self.combo_box.addItems(geek_list)
# setting style sheet of combo box
# adding skin to the combo box when it is non-editable
# and when it in off state and mouse hover over it
self.combo_box.setStyleSheet("QComboBox::! editable:! on:hover"
"{"
"border-image : url(image.png);"
"border : 1px solid black;"
"}")
# create pyqt5 app
App = QApplication(sys.argv)
# create the instance of our Window
window = Window()
window.show()
# start the app
sys.exit(App.exec())
输出 :