我有一个用PyQt5制作的小GUI,它基本上由一个实时绘图和两个用于停止和继续的按钮组成。我想每measure_interval
毫秒更新一次绘图。在我的脚本中,我将其设置为1000(1秒)。该程序开始正常运行,但是当我按下“停止”按钮然后以“启动”继续运行时,即使时间间隔未更改,计时器也似乎会加速。实际上,每当我按下“开始”按钮时,绘图速度都会加快(即使之前没有停止过)。因此,即使我无法发现错误,我仍然相信错误在那里。这是我的代码:
import numpy as np
from matplotlib.backends.qt_compat import QtWidgets
from matplotlib.backends.backend_qt5agg import FigureCanvas
from matplotlib.figure import Figure
class ApplicationWindow(QtWidgets.QMainWindow):
def __init__(self):
global measure_interval
super(ApplicationWindow, self).__init__()
self._main = QtWidgets.QWidget()
self.setCentralWidget(self._main)
# Canvas
dynamic_canvas = FigureCanvas(Figure(figsize=(10, 10)))
self._dynamic_ax = dynamic_canvas.figure.subplots()
self._timer = dynamic_canvas.new_timer(measure_interval, [(self._update_window, (), {})])
self._timer.start()
# Buttons
button_stop = QtWidgets.QPushButton('Stop', self)
button_stop.clicked.connect(self._timer.stop)
button_start = QtWidgets.QPushButton('Start', self)
button_start.clicked.connect(self._timer.start)
# Layout
layout = QtWidgets.QVBoxLayout(self._main)
layout.addWidget(dynamic_canvas)
layout.addWidget(button_stop)
layout.addWidget(button_start)
def _update_window(self):
global x, y, win_size, count_iter
# Update variables
x.append(x[count_iter] + 0.01)
y.append(np.random.random())
idx_inf = max([count_iter-win_size, 0])
count_iter += 1
# Plot
self._dynamic_ax.clear()
self._dynamic_ax.plot(x[idx_inf:count_iter], y[idx_inf:count_iter],'-o', color='b')
self._dynamic_ax.figure.canvas.draw()
#%%
if __name__ == "__main__":
measure_interval = 1000 # milisegs
win_size = 100 # maximum window size (samples)
y = [np.random.random()]
x = [0]
count_iter = 0
qapp = QtWidgets.QApplication([])
app = ApplicationWindow()
app.show()
qapp.exec_()
答案 0 :(得分:1)
按下开始按钮时,计时器间隔将重置为0
。
这是由于.start()
函数采用参数interval
来设置计时器的间隔。
但是,当将start()
直接用作按钮的clicked
信号的回调时,某些状态False
将提供给回调。因此,基本上,当按下按钮时,您会呼叫start(False)
。与python中的start(0)
相同,因此间隔设置为0
。
为避免这种情况,可以使用lambda函数并确保不带参数调用start()
,在这种情况下,它将记住最初设置的intervall并使用它。
button_start.clicked.connect(lambda : self._timer.start())