w3resource

Python PyQt program - Customize appearance

Python PyQt Widgets: Exercise-6 with Solution

Write a Python program that customizes the appearance of a label text color, input field background color and a push button to close the dialog using PyQt.

From doc.qt.io:

QDialog Class: The QDialog class is the base class of dialog windows.

QVBoxLayout Class: The QVBoxLayout class lines up widgets vertically.

QLabel Class: The QLabel widget provides a text or image display.

QLineEdit Class: A line edit allows the user to enter and edit a single line of plain text with a useful collection of editing functions, including undo and redo, cut and paste, and drag and drop.

QPushButton: The push button, or command button, is perhaps the most commonly used widget in any graphical user interface. Push (click) a button to command the computer to perform some action, or to answer a question. Typical buttons are OK, Apply, Cancel, Close, Yes, No and Help.

QPalette Class: The QPalette class contains color groups for each widget state.

QColor Class: The QColor class provides colors based on RGB, HSV or CMYK values.

Sample Solution:

Python Code:

from PyQt5.QtWidgets import QDialog, QVBoxLayout, QLabel, QLineEdit, QPushButton
from PyQt5.QtGui import QPalette, QColor
class CustomDialog(QDialog):
    def __init__(self):
        super().__init__()

        # Set the window properties (title and initial size)
        self.setWindowTitle("Custom Dialog")
        self.setGeometry(100, 100, 300, 150)  # (x, y, width, height)

        # Create a layout for the dialog
        layout = QVBoxLayout()

        # Create a QLabel with custom text color
        label = QLabel("Input your name:")
        palette = QPalette()
        palette.setColor(QPalette.Foreground, QColor("red"))
        label.setPalette(palette)

        # Create a QLineEdit with custom background color
        line_edit = QLineEdit()
        line_edit.setStyleSheet("background-color: orange;")

        # Create a QPushButton to close the dialog
        close_button = QPushButton("Close")
        close_button.clicked.connect(self.close)

        # Add widgets to the layout
        layout.addWidget(label)
        layout.addWidget(line_edit)
        layout.addWidget(close_button)

        # Set the layout for the dialog
        self.setLayout(layout)

def main():
    dialog = CustomDialog()
    dialog.exec_()

if __name__ == "__main__":
    main()

Explanation:

In the exercise above -

  • Import the necessary modules.
  • Create a custom "QDialog" named "CustomDialog".
  • Set the dialog's title and initial size.
  • Create a QVBoxLayout to arrange widgets vertically.
  • Create a QLabel with the text "Input your name:" and customize its text color to red using QPalette.
  • Create a QLineEdit and customize its background color to light yellow using setStyleSheet.
  • Create a QPushButton labeled "Close" and connect its click event to close the dialog.
  • Add QLabel, QLineEdit, and QPushButton to the QVBoxLayout.
  • Set the QVBoxLayout as the dialog layout.
  • In the main() function, we create the PyQt application, create an instance of the "CustomDialog" class, show the window, and run the application's event loop.

Output:

PyQt: Python PyQt program - Customize appearance . Part-1
PyQt: Python PyQt program - Customize appearance . Part-2

Flowchart:

Flowchart: Python PyQt program - Customize appearance .
Flowchart: Python PyQt program - Customize appearance .

Python Code Editor:


Previous: Button color changer.
Next: Image viewer.

What is the difficulty level of this exercise?

Test your Programming skills with w3resource's quiz.



Become a Patron!

Follow us on Facebook and Twitter for latest update.

It will be nice if you may share this link in any developer community or anywhere else, from where other developers may find this content. Thanks.

https://www.w3resource.com/python-exercises/pyqt/python-pyqt-widgets-exercise-6.php