PyQt5 QDockWidget – Configuración de la hoja de estilo

En este artículo veremos cómo podemos configurar la hoja de estilo para el QDockWidget. QDockWidget proporciona el concepto de widgets de base, también conocidos como paletas de herramientas o ventanas de utilidades. Las ventanas del muelle son ventanas secundarias ubicadas en el área del widget del muelle alrededor del widget central en una QMainWindow (ventana original). La hoja de estilo representa el estilo, es decir, el aspecto del widget, consiste en características de color, espaciado, relleno y borde.
 

Para hacer esto, usaremos el método setStyleSheet con el objeto del widget del muelle.
Sintaxis: dock.setStyleSheet (estilo)
Argumento: toma una string como argumento
Retorno: devuelve Ninguno 
 

A continuación se muestra el código de hoja de estilo de ejemplo 
 

QDockWidget
{
background : lightgreen;
}
QDockWidget::title
{
background : lightblue;
}
QDockWidget QPushButton
{
border : 2px solid black;
background : darkgreen;
}

Nota: aquí hemos usado QDockWidget::QPushButton porque hemos agregado botones en el muelle. Podemos usar otro nombre de widget si se agrega cualquier otro widget.
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, 500, 400)
 
        # calling method
        self.UiComponents()
 
        # showing all the widgets
        self.show()
 
    # method for components
    def UiComponents(self):
 
        # creating dock widget
        dock = QDockWidget(self)
 
        # setting title to the dock widget
        dock.setWindowTitle("GfG Title")
 
        # creating a QWidget object
        widget = QWidget(self)
 
        # creating a vertical box layout
        layout = QVBoxLayout(self)
 
        # push button 1
        push1 = QPushButton("A", self)
 
        # push button 2
        push2 = QPushButton("B", self)
 
        # adding these buttons to the layout
        layout.addWidget(push1)
        layout.addWidget(push2)
 
        # setting the layout to the widget
        widget.setLayout(layout)
 
        # adding widget to the layout
        dock.setWidget(widget)
 
        # creating a label
        label = QLabel("GeesforGeeks", self)
 
        # setting geometry to the label
        label.setGeometry(100, 200, 300, 80)
 
        # making label multi line
        label.setWordWrap(True)
 
        # setting geometry to the dock widget
        dock.setGeometry(100, 0, 200, 30)
 
        # setting style sheet to the  dock widget
        dock.setStyleSheet("QDockWidget"
                           "{"
                           "background : lightgreen;"
                           "}"
                           "QDockWidget::title"
                           "{"
                           "background : lightblue;"
                           "}"
                           "QDockWidget QPushButton"
                           "{"
                           "border : 2px solid black;"
                           "background : darkgreen;"
                           "}"
                           )
 
 
 
 
# 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 *