PyQt5 QCommandLinkButton: configuración del color de fondo para los estados de desplazamiento

En este artículo, veremos cómo podemos establecer el color de fondo del QCommandLinkButton de acuerdo con los estados de desplazamiento. El botón de enlace de comando es un tipo especial de botón que tiene cualidades tanto de botón pulsador como de botón de opción. De forma predeterminada, no hay un color de fondo adicional para el botón de enlace de comando, aunque podemos establecer un color de fondo personalizado en cualquier momento.

Básicamente, hay dos estados de desplazamiento, uno está flotando, es decir, cuando el mouse está en el botón de enlace de comando y el segundo es un estado antidesplazamiento, es decir, cuando el cursor no está en el botón de enlace de comando.

Para hacer esto, configuraremos el código de la hoja de estilo para eso, usamos setStyleSheetel método con el objeto del botón de enlace de comando, a continuación se muestra el código de la hoja de estilo.

QCommandLinkButton::hover
{
background-color : lightgreen;
}
QCommandLinkButton::!hover
{
background-color : yellow;
}

A continuación se muestra la implementación.

# 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 the hover state
        cl_button.setStyleSheet("QCommandLinkButton::hover"
                                "{"
                                "border : 1px solid black;"
                                "background-color : lightgreen;"
                                "}"
                                "QCommandLinkButton::! hover"
                                "{"
                                "border : 1px solid black;"
                                "background-color : yellow;"
                                "}")
  
  
  
  
# create pyqt5 app
App = QApplication(sys.argv)
  
# create the instance of our Window
window = Window()
  
# 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

Deja una respuesta

Tu dirección de correo electrónico no será publicada. Los campos obligatorios están marcados con *