PyQt5:带有延迟的 QSlider valueChanged 事件

PyQt5: QSlider valueChanged event with delay

我在我的 GUI 应用程序中使用 QSlider,以便在 QSlider 中的值更改后执行繁重的任务。我这样做如下。

self.slider.valueChanged.connect(self.value_changed)  # Inside __init__() function

def value_changed(self):  # Inside the class
    # Do the heavy task

但我无法顺利更改滑块的值,因为每次更改值的任务繁重 运行ning。

我需要的是运行值改变后的繁重任务,但前提是滑块的值暂时没有改变。

我不知道如何在 python 中执行此操作。有帮助吗..?

您可以使用startTimer/killTimer来延迟您的任务:

class Foo(QWidget):
    def __init__(self):
        super().__init__()
        self.timer_id = -1
        self.slider = QSlider(self)
        self.slider.setMinimum(0)
        self.slider.setMaximum(100)
        self.slider.valueChanged.connect(self.value_changed)

    def timerEvent(self, event):
        self.killTimer(self.timer_id)
        self.timer_id = -1
        heavy_task()

    def value_changed(self):
        if self.timer_id != -1:
            self.killTimer(self.timer_id)

        self.timer_id = self.startTimer(3000)

所以,你可以看到我们每次都重新启动计时器 用户发生了一些变化,所以如果 3000 毫秒没有过期 自上次更改 heavy_task 而非 运行、

但无论如何它都会在主线程中 运行ning,所以对于某些人来说 时间界面冻结用户,所以你应该使用 QThreadtimerEvent 中没有不冻结的界面 heavy_task执行。

我不是专家,我在战斗结束后很久才到达,但我也需要这样的东西,而且我对计时器一无所知。它适用于一个滑块,但我需要 3 个。所以我想出了这个解决方案:当按下滑块时,我断开 valueChanged 插槽,当滑块被释放时,我重新连接它并抛出一个 valueChanged 信号,比如这 :

    self.sldAZap.valueChanged.connect(self.sliderChanged)
    self.sldAZap.sliderPressed.connect(self.sldDisconnect)
    self.sldAZap.sliderReleased.connect(self.sldReconnect)

def sldDisconnect(self):
    self.sender().valueChanged.disconnect()

def sldReconnect(self):
    self.sender().valueChanged.connect(self.sliderChanged)
    self.sender().valueChanged.emit(self.sender().value())

def sliderChanged(self):
    print(self.sender().objectName() + " : " + str(self.sender().value())

采用该方案,从松开鼠标到执行代码之间没有延迟,代码只执行一次。

我希望我说得足够清楚,它可能会对某人有所帮助。