PyQt5 – 可编辑的组合框被按下时的背景图片

PyQt5 – 可编辑的组合框被按下时的背景图片

在这篇文章中,我们将看到如何在可编辑的组合框被按下时为其设置背景图片。默认情况下,组合框是没有图像的,尽管我们可以为它设置图像。只有当组合框处于可编辑状态和组合框被按下时,背景图片才会出现。在setEditable方法的帮助下,普通的组合框可以变得可编辑。

为了做到这一点,我们必须改变与组合框相关的样式表,下面是样式表代码

QComboBox::editable:pressed
{
background-image : url(image.png);
border : 2px solid black;
}

注意: 组合框和文本视图是不同的东西 文本视图是组合框的组成部分
以下是实现情况 –

# 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)
 
        # making combo box editable
        self.combo_box.setEditable(True)
 
        # setting geometry of combo box
        self.combo_box.setGeometry(200, 150, 200, 80)
 
        # 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 the combo box
        # adding background image to the combo box it is in editable state
        # and when combo box get pressed
        self.combo_box.setStyleSheet("QComboBox::editable:pressed"
                                     "{"
                                     "background-image : url(logo.png);"
                                     "border : 2px 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())

Python教程

Java教程

Web教程

数据库教程

图形图像教程

大数据教程

开发工具教程

计算机教程