PyQt5 QCommandLinkButton: color de fondo para los estados combinados marcados y presionados

En este artículo, veremos cómo podemos establecer el color de fondo en la casilla de verificación QCommandLinkButtonde acuerdo con los estados marcados y de desplazamiento combinados. 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 radio. 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.

Podemos hacer que el botón de enlace de comando se pueda verificar con la ayuda del setCheckablemétodo, básicamente hay dos estados verificados, uno está verificado, es decir, cuando está presionado y otro es el estado no verificado, es decir, cuando está liberado.

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::checked
{
background-color : lightgreen;
}
QCommandLinkButton::checked::pressed
{
background-color : yellow;
}
QCommandLinkButton::!checked
{
background-color : red;
}
QCommandLinkButton::!checked::pressed
{
background-color : pink;
}

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 checked state
        # adding background color for checked pressed state combine
        cl_button.setStyleSheet("QCommandLinkButton::checked"
                                "{"
                                "border : 1px solid black;"
                                "background-color : lightgreen;"
                                "}"
                                "QCommandLinkButton::checked::pressed"
                                "{"
                                "border : 1px solid black;"
                                "background-color : yellow;"
                                "}"
                                "QCommandLinkButton::! checked"
                                "{"
                                "border : 1px solid black;"
                                "background-color : red;"
                                "}"
                                "QCommandLinkButton::! checked::pressed"
                                "{"
                                "border : 1px solid black;"
                                "background-color : pink;"
                                "}")
  
  
  
  
# 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 *