pyqtgraph 设置线程阻塞
如果想要在 PyQtGraph 应用程序中设置线程阻塞以模拟一个耗时长的任务,可以使用 time.sleep 或者其他会阻塞线程的操作。以下是一个简单的示例:
import pyqtgraph as pg
from PyQt5.QtCore import Qt, QThread, pyqtSignal
import timeclass LongRunningTask(QThread):finished = pyqtSignal()def run(self):# 模拟一个耗时长的任务for i in range(10):time.sleep(1) # 模拟一个耗时 1 秒的操作self.finished.emit()class MainApplication:def __init__(self):self.app = pg.mkQApp()# 创建一个 PlotWidgetself.plot_widget = pg.PlotWidget()self.plot_widget.plot([1, 2, 3, 4, 5], [1, 2, 3, 4, 5])# 连接鼠标点击事件到自定义函数self.plot_widget.scene().sigMouseClicked.connect(self.mouseClickEvent)# 显示 PlotWidgetself.plot_widget.show()# 启动 PyQtGraph 事件循环self.app.exec_()def mouseClickEvent(self, event):if event.button() == Qt.LeftButton:# 在一个线程中运行一个耗时长的任务self.runLongTask()def runLongTask(self):# 创建一个长时间运行的任务线程long_running_thread = LongRunningTask()long_running_thread.finished.connect(self.longTaskFinished)long_running_thread.start()# 阻塞主线程,等待任务完成long_running_thread.wait()def longTaskFinished(self):print("Long-running task finished")# 创建一个示例类的实例
main_application = MainApplication()
在这个例子中,LongRunningTask 类继承自 QThread,并模拟了一个每次耗时 1 秒的任务循环,总共循环 10 次。在 runLongTask 方法中,创建了一个 LongRunningTask 的实例,连接了 finished 信号到 longTaskFinished 方法,然后启动了线程并使用 wait 方法阻塞了主线程,直到任务完成。
请注意,阻塞主线程可能导致界面冻结,因此在实际应用中,最好将耗时的任务放在单独的线程中,以确保主线程保持响应性。上述例子仅用于演示如何阻塞主线程。