pyqtgraph 设置线程阻塞

pyqtgraph 设置线程阻塞

如果想要在 PyQtGraph 应用程序中设置线程阻塞以模拟一个耗时长的任务,可以使用 time.sleep 或者其他会阻塞线程的操作。以下是一个简单的示例:

import pyqtgraph as pg
from PyQt5.QtCore import Qt, QThread, pyqtSignal
import time

class 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()

        # 创建一个 PlotWidget
        self.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)

        # 显示 PlotWidget
        self.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 方法阻塞了主线程,直到任务完成。

请注意,阻塞主线程可能导致界面冻结,因此在实际应用中,最好将耗时的任务放在单独的线程中,以确保主线程保持响应性。上述例子仅用于演示如何阻塞主线程。

你可能感兴趣的:(qt,pyqt,pyqtgraph,数据处理,数据可视化,python)