PyQt5 QCommandLinkButton: configuración de borde para estados de desplazamiento

En este artículo, veremos cómo podemos configurar el borde 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 radio. De forma predeterminada, no hay un borde adicional en el botón de enlace de comando, aunque cuando se presiona podemos ver el borde, también podemos configurar un borde personalizado. 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
{
border : 4px solid green;
}
QCommandLinkButton::!hover
{
border : 2px solid red;
}

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)
  
        cl_button.setCheckable(True)
  
        # setting geometry
        cl_button.setGeometry(250, 100, 200, 50)
  
        # setting style sheet
        # setting border to it for hover and anti hover state
        cl_button.setStyleSheet("QCommandLinkButton::hover"
                                "{"
                                "border : 4px solid green;"
                                "}"
                                "QCommandLinkButton::! hover"
                                "{"
                                "border : 2px solid red;"
                                "}")
  
  
  
  
# 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 *