Как сделать QPushButton кнопкой загрузки? - PullRequest
0 голосов
/ 04 декабря 2018

Есть ли способ сделать кнопку загрузки из QPushButton?Я хочу сделать что-то вроде https://coreui.io/docs/components/loading-buttons/, но в Qt.Возможно ли это?

Я хотел бы сделать индикатор загрузки / прогресса из каждого элемента виджета списка, как показано ниже.

enter image description here

1 Ответ

0 голосов
/ 04 декабря 2018

Вы можете использовать QMovie, чтобы загрузить gif и установить его как значок в QPushButton, в следующем примере реализуйте метод start и stop, который запускает и заканчивает анимацию, соответственно, и метод setGif, который проходит путь gif:

from PyQt5 import QtCore, QtGui, QtWidgets

class LoadingButton(QtWidgets.QPushButton):
    @QtCore.pyqtSlot()
    def start(self):
        if hasattr(self, "_movie"):
            self._movie.start()

    @QtCore.pyqtSlot()
    def stop(self):
        if hasattr(self, "_movie"):
            self._movie.stop()
            self.setIcon(QtGui.QIcon())

    def setGif(self, filename):
        if not hasattr(self, "_movie"):
            self._movie = QtGui.QMovie(self)
            self._movie.setFileName(filename)
            self._movie.frameChanged.connect(self.on_frameChanged)
            if self._movie.loopCount() != -1:
                self._movie.finished.connect(self.start)
        self.stop()

    @QtCore.pyqtSlot(int)
    def on_frameChanged(self, frameNumber):
        self.setIcon(QtGui.QIcon(self._movie.currentPixmap()))

if __name__ == '__main__':
    import sys
    import random
    app = QtWidgets.QApplication(sys.argv)
    w = QtWidgets.QWidget()
    lay = QtWidgets.QVBoxLayout(w)
    for i in range(5):
        button = LoadingButton("Install")
        button.setGif("loading.gif")
        QtCore.QTimer.singleShot(random.randint(3000, 6000), button.start)
        QtCore.QTimer.singleShot(random.randint(8000, 12000), button.stop)
        lay.addWidget(button)
    w.show()
    sys.exit(app.exec_())

loading.gif

enter image description here

enter image description here

...