En este artículo, veremos cómo podemos establecer la imagen de fondo en la parte de edición de línea del cuadro combinado no editable cuando se pasa el mouse sobre él. La edición de línea es la parte del cuadro combinado que se utiliza para ver el texto seleccionado y editar el texto. Para configurar y obtener el objeto de edición de línea del cuadro combinado, usamos el método setLineEdit y lineEdit.
Nota: Cuando agregamos edición de línea al cuadro combinado, hace que el cuadro combinado sea editable, por lo tanto, es necesario hacer que la edición de línea no sea editable.
Para ello tenemos que hacer lo siguiente
1. Cree un cuadro combinado
2. Agregue elementos al cuadro combinado
3. Cree un objeto QLineEdit
4. Agregue una imagen de fondo al objeto QLineEdit cuando pase el mouse sobre él
5. Haga que el objeto de edición de línea no sea editable
6. Agregue el objeto de edición de línea a el cuadro combinado
Sintaxis:
# creating line edit object line_edit = QLineEdit() # setting style sheet of line edit # adding background image when mouse hover over it line_edit.setStyleSheet("QLineEdit::hover" "{" "background-image : url(logo.png);" "border : 2px solid black;" "}") # making line edit object non editable line_edit.setReadOnly(True) # adding line edit to the combo box combo_box.setLineEdit(line_edit)
A continuación se muestra la implementación.
Python3
# 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) # creating line edit object line_edit = QLineEdit() # setting style sheet of line edit # adding background image when mouse hover over it line_edit.setStyleSheet("QLineEdit::hover" "{" "background-image : url(logo.png);" "border : 2px solid black;" "}") # making line edit object non editable line_edit.setReadOnly(True) # adding line edit to the combo box self.combo_box.setLineEdit(line_edit) # create pyqt5 app App = QApplication(sys.argv) # create the instance of our Window window = Window() window.show() # start the app sys.exit(App.exec())
Producción :
Publicación traducida automáticamente
Artículo escrito por rakshitarora y traducido por Barcelona Geeks. The original can be accessed here. Licence: CCBY-SA