w3resource

Python custom progress bar widget with PyQt

Python PyQt Widgets: Exercise-12 with Solution

Write a Python program to create a custom progress bar widget that displays a progress percentage using PyQt. Create methods to set and update progress values.

From doc.qt.io:

QApplication Class: The QApplication class manages the GUI application's control flow and main settings.

QWidget Class: The QWidget class is the base class of all user interface objects.

QVBoxLayout Class: The QVBoxLayout class lines up widgets vertically.

QPushButton Class: The QPushButton widget provides a command button.

QPainter Class: The QPainter class performs low-level painting on widgets and other paint devices.

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

QFont Class: The QFont class specifies a query for a font used for drawing text.

Sample Solution:

Python Code:

import sys
from PyQt5.QtWidgets import QApplication, QWidget, QVBoxLayout, QPushButton
from PyQt5.QtGui import QPainter, QColor, QFont
from PyQt5.QtCore import Qt, QTimer

class CustomProgressBar(QWidget):
    def __init__(self):
        super().__init__()
        self.setMinimumSize(300, 50)
        self.progress = 0

    def set_progress(self, value):
        self.progress = value
        self.update()

    def paintEvent(self, event):
        painter = QPainter(self)
        painter.setRenderHint(QPainter.Antialiasing)

        # Define progress bar dimensions
        bar_width = 250
        bar_height = 30
        bar_x = (self.width() - bar_width) / 2
        bar_y = (self.height() - bar_height) / 2

        # Draw the background of the progress bar
        painter.setPen(Qt.NoPen)
        painter.setBrush(QColor(200, 200, 200))
        painter.drawRect(bar_x, bar_y, bar_width, bar_height)

        # Draw the filled portion of the progress bar
        fill_width = int(bar_width * (self.progress / 100))
        painter.setBrush(QColor(0, 160, 230))
        painter.drawRect(bar_x, bar_y, fill_width, bar_height)

        # Display progress percentage text
        font = QFont("Arial", 12)
        painter.setFont(font)
        painter.setPen(QColor(0, 0, 0))
        text = f"{int(self.progress)}%"
        text_width = painter.fontMetrics().width(text)
        text_x = (self.width() - text_width) / 2
        text_y = bar_y + bar_height + 20
        painter.drawText(text_x, text_y, text)

class ProgressBarApp(QWidget):
    def __init__(self):
        super().__init__()
        self.setWindowTitle("Custom Progress Bar")
        self.setGeometry(100, 100, 400, 200)

        layout = QVBoxLayout()
        self.progress_bar = CustomProgressBar()
        layout.addWidget(self.progress_bar)

        self.button = QPushButton("Start Progress")
        self.button.clicked.connect(self.start_progress)
        layout.addWidget(self.button)

        self.setLayout(layout)

        # Initialize timer for smooth progress update
        self.timer = QTimer(self)
        self.timer.timeout.connect(self.update_progress)

    def start_progress(self):
        self.progress = 0
        self.button.setEnabled(False)
        self.timer.start(100)  # Update every 100 milliseconds

    def update_progress(self):
        if self.progress <= 100:
            self.progress_bar.set_progress(self.progress)
            self.progress += 1
        else:
            self.timer.stop()
            self.button.setEnabled(True)

def main():
    app = QApplication(sys.argv)
    window = ProgressBarApp()
    window.show()
    sys.exit(app.exec_())

if __name__ == "__main__":
    main()

Explanation:

In the exercise above -

  • Import the necessary modules from PyQt5.
  • Create a CustomProgressBar class that subclasses QWidget to create the custom progress bar widget.
  • The "set_progress()" method allows you to set the progress value and triggers a repaint of the progress bar.
  • In the "paintEvent()" method, we use QPainter to draw the progress bar and the filled portion based on the progress value.
  • Display the progress percentage text below the progress bar.
  • The "ProgressBarApp" class creates the main application window with a custom progress bar and a button to start progress updates.
  • Added a QTimer named timer to the ProgressBarApp class. This timer periodically calls the "update_progress()" method.
  • The "start_progress()" initializes the progress value and starts the timer to update the progress every 100 milliseconds.
  • It is disabled during progress updates and enabled after completion.

Output:

PyQt: Python custom progress bar widget with PyQt. Part-1
PyQt: Python custom progress bar widget with PyQt. Part-2
PyQt: Python custom progress bar widget with PyQt. Part-3

Flowchart:

Flowchart: Python custom progress bar widget with PyQt.
Flowchart: Python custom progress bar widget with PyQt.
Flowchart: Python custom progress bar widget with PyQt.

Python Code Editor:


Previous: Messaging interface.

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://w3resource.com/python-exercises/pyqt/python-pyqt-widgets-exercise-12.php