从不同类添加的小部件中的PyQt5停止计时器

2024-10-05 14:28:14 发布

您现在位置:Python中文网/ 问答频道 /正文

我想在多个窗口的顶部显示当前日期和时间,所以我创建了一个这个顶部小部件的类。但是,当我切换到另一个窗口时,计时器也会在上一个窗口上运行。如何在切换窗口之前停止计时器,或者在新窗口上保持相同的实例运行

from PyQt5 import QtCore
from PyQt5 import QtWidgets
from PyQt5.QtWidgets import QApplication, QMainWindow, QHBoxLayout, QWidget
import sys
from datetime import datetime

CurrentWindow = None

class TopBar(QWidget):
    def __init__(self):
        super().__init__()
        self.initUI()

    def initUI(self):
        self.labelTime = QtWidgets.QLabel(self)
        self.labelTime.setStyleSheet("background-color: rgba(0, 0, 0, 0); color: white")

        background = QtWidgets.QWidget(self)
        background.setStyleSheet("background-color: rgba(0, 191, 255, 0.6)")
        background.setGeometry(0, 0, 480, 30)

        hbox = QHBoxLayout(background)
        hbox.setContentsMargins(10, 0, 10, 0)
        hbox.addWidget(self.labelTime, alignment=QtCore.Qt.AlignRight)

        self.timer = QtCore.QTimer(self)
        self.timer.setInterval(1000)
        self.timer.timeout.connect(self.displayTime)
        self.timer.start()

        self.displayTime()


    def displayTime(self):
        print(self.parent())
        self.labelTime.setText(datetime.now().strftime("%Y/%m/%d %H:%M:%S"))


class Window1(QMainWindow):
    def __init__(self):
        super().__init__()
        self.initUI()

    def initUI(self):
        self.resize(480, 320)

        self.centralwidget = QtWidgets.QWidget(self)
        self.setCentralWidget(self.centralwidget)

        widgetTop = QtWidgets.QWidget(self.centralwidget)
        widgetTop.setGeometry(0, 0, 480, 30)

        layoutTop = QHBoxLayout(widgetTop)
        layoutTop.addWidget(TopBar())
        layoutTop.setContentsMargins(0, 0, 0, 0)

        self.pushButton = QtWidgets.QPushButton(self.centralwidget)
        self.pushButton.setText('Go to Window2')
        self.pushButton.clicked.connect(self.goToWindow2)

        layoutCenter = QHBoxLayout(self.centralwidget)
        layoutCenter.addWidget(self.pushButton, alignment=QtCore.Qt.AlignCenter)

        self.show()


    def goToWindow2(self):
        global CurrentWindow
        CurrentWindow = Window2()
        self.close()


class Window2(QMainWindow):
    def __init__(self):
        super().__init__()
        self.initUI()

    def initUI(self):
        self.resize(480, 320)

        self.centralwidget = QtWidgets.QWidget(self)
        self.setCentralWidget(self.centralwidget)

        widgetTop = QtWidgets.QWidget(self.centralwidget)
        widgetTop.setGeometry(0, 0, 480, 30)

        layoutTop = QHBoxLayout(widgetTop)
        layoutTop.addWidget(TopBar())
        layoutTop.setContentsMargins(0, 0, 0, 0)

        self.pushButton = QtWidgets.QPushButton(self.centralwidget)
        self.pushButton.setText('Go to Window1')
        self.pushButton.clicked.connect(self.goToWindow1)

        layoutCenter = QHBoxLayout(self.centralwidget)
        layoutCenter.addWidget(self.pushButton, alignment=QtCore.Qt.AlignCenter)

        self.show()


    def goToWindow1(self):
        global CurrentWindow
        CurrentWindow = Window1()
        self.close()



if __name__=='__main__':
    app = QApplication(sys.argv)
    ex = Window1()
    sys.exit(app.exec_())

Tags: importselfinitdefbackgroundqwidgetqtcoreqtwidgets
1条回答
网友
1楼 · 发布于 2024-10-05 14:28:14

我不认为QTimer的执行会减慢应用程序的速度

但我仍然会告诉你如何从另一个窗口阻止它。要做到这一点,您必须访问该对象,这样您就必须成为该类的成员,然后在更改窗口时,使用QTimer的stop方法停止该窗口

class Window1(QMainWindow):
    # ...

    def initUI(self):
        # ...
        layoutTop = QHBoxLayout(widgetTop)
        self.topbar = TopBar()
        layoutTop.addWidget(self.topbar)
        layoutTop.setContentsMargins(0, 0, 0, 0)
        # ...

    def goToWindow2(self):
        global CurrentWindow
        self.topbar.timer.stop()
        CurrentWindow = Window2()
        self.close()


class Window2(QMainWindow):
    # ...

    def initUI(self):
        # ...
        layoutTop = QHBoxLayout(widgetTop)
        self.topbar = TopBar()
        layoutTop.addWidget(self.topbar)
        layoutTop.setContentsMargins(0, 0, 0, 0)
        # ...

    def goToWindow1(self):
        global CurrentWindow
        self.topbar.timer.stop()
        CurrentWindow = Window1()
        self.close()

如果你仍然认为错误的原因是有几个QTIMER,那么在下面的代码中只有一个TopBar,他们将使用QStaskDeWIDGET

改变小部件。
from PyQt5 import QtCore
from PyQt5 import QtWidgets
from PyQt5.QtWidgets import QApplication, QMainWindow, QHBoxLayout, QWidget
import sys
from datetime import datetime


class TopBar(QWidget):
    def __init__(self):
        super().__init__()
        self.initUI()

    def initUI(self):
        self.setAttribute(QtCore.Qt.WA_StyledBackground)
        self.labelTime = QtWidgets.QLabel()
        self.labelTime.setStyleSheet("background-color: rgba(0, 0, 0, 0); color: white")

        self.setStyleSheet("background-color: rgba(0, 191, 255, 0.6)")
        self.setFixedHeight(30)

        hbox = QHBoxLayout(self)
        hbox.setContentsMargins(10, 0, 10, 0)
        hbox.addWidget(self.labelTime, alignment=QtCore.Qt.AlignRight)

        self.timer = QtCore.QTimer(self)
        self.timer.setInterval(1000)
        self.timer.timeout.connect(self.displayTime)
        self.timer.start()

        self.displayTime()

    def displayTime(self):
        self.labelTime.setText(datetime.now().strftime("%Y/%m/%d %H:%M:%S"))


class Window(QWidget):
    changeWindow = QtCore.pyqtSignal(int)

    def changeTo(self, index):
        def callback():
            self.changeWindow.emit(index)

        return callback


class Window1(Window):
    def __init__(self):
        super().__init__()
        self.initUI()

    def initUI(self):
        self.pushButton = QtWidgets.QPushButton()
        self.pushButton.setText("Go to Window2")
        self.pushButton.clicked.connect(self.changeTo(1))

        layoutCenter = QHBoxLayout(self)
        layoutCenter.addWidget(self.pushButton, alignment=QtCore.Qt.AlignCenter)


class Window2(Window):
    def __init__(self):
        super().__init__()
        self.initUI()

    def initUI(self):
        self.pushButton = QtWidgets.QPushButton()
        self.pushButton.setText("Go to Window1")
        self.pushButton.clicked.connect(self.changeTo(0))

        layoutCenter = QHBoxLayout(self)
        layoutCenter.addWidget(self.pushButton, alignment=QtCore.Qt.AlignCenter)


class MainWindow(QtWidgets.QMainWindow):
    def __init__(self, parent=None):
        super().__init__(parent)
        self.initUI()

    def initUI(self):
        self.resize(480, 320)

        self.centralwidget = QtWidgets.QWidget(self)
        self.setCentralWidget(self.centralwidget)

        self.topbar = TopBar()
        lay = QtWidgets.QVBoxLayout(self.centralwidget)
        lay.setContentsMargins(0, 0, 0, 0)
        lay.addWidget(self.topbar)

        stacked_widget = QtWidgets.QStackedWidget()
        lay.addWidget(stacked_widget)

        for w in (Window1(), Window2()):
            stacked_widget.addWidget(w)
            if isinstance(w, Window):
                w.changeWindow.connect(stacked_widget.setCurrentIndex)


if __name__ == "__main__":
    app = QApplication(sys.argv)
    w = MainWindow()
    w.show()
    sys.exit(app.exec_())

相关问题 更多 >