PyQt5中的定时器QTimer设置与失效分析

前言

PyQt是Python语言环境的GUI编程解决方案之一,另外还有PyGTK、wxPython等也较为常用。PyQt作为Qt语言的Python扩展,可以用来方便快速的开发界面应用。
在这里插入图片描述

PyQt5中的定时器QTimer设置

在这里插入图片描述

import os.path as osp
from qtpy import QtCore
from qtpy import QtWidgets

# TracelessLe注:代码示例,不可直接执行

class MainWindow(QtWidgets.QMainWindow):
	def __init__(self):
	self.play_timer = QtCore.QTimer(self)
    self.play_timer.timeout.connect(self.openNextFrame)  # 槽函数在此设置

    def openNextFrame(self, _value=False, load=True):
        if self.frames_len <= 0:
            return

        if self.frame_index + 1 < self.frames_len:
            self.frame_index += 1
            self.openFrameById()  # 打开视频帧

        if self.frame_index == self.frames_len - 1:
            self.play_timer.stop()

    def play(self):
        if self.play_timer.isActive():  # 正在播放状态,icon此时为暂停
            self.pause()  # 再按一次暂停
        else:
            delay_time = 40  # default fps ~= 24
            if self.frame_index == self.frames_len - 1:
                self.openFrameById()
            if not self.play_timer.isActive():  # 定时器未激活状态
                self.play_timer.start(delay_time)  # ms
                #self.play_timer.timeout.connect(self.openNextFrame)  # 槽函数不能在此设置,否则self.play二次运行时定时器设置将失效

    def pause(self):
        self.play_timer.stop()	

定时器QTimer设置失效分析

当上述代码中,self.play_timer.timeout.connect(self.openNextFrame)设置在self.play函数中时,会遇到再次运行播放功能时,所设置的定时器参数失效,具体表现为第一次播放所有视频帧能按正常时间间隔刷新画布,但是再次运行播放时画布刷新非常快,设置的刷新间隔失效。

通过查阅资料,发现参考资料[3]中有一点说的很有道理:
在这里插入图片描述
回到代码中发现确实是每次调用self.play方法时定时器的connect都会被重新设置。于是考虑将这个槽函数放回到__init__方法中,也就是上述代码中的位置。

重新运行后发现能正常按所设刷新间隔重复播放。

版权说明

本文为原创文章,独家发布在blog.csdn.net/TracelessLe。未经个人允许不得转载。如需帮助请email至tracelessle@163.com
在这里插入图片描述

参考资料

[1] QTimer Class | Qt Core 5.15.8
[2] What is PyQt?
[3] QTimer计时速度不断加快问题和QT中show函数失效问题的思考和处理_chen9807的博客-CSDN博客
[4] Qt 之 QTimer_青春不老,奋斗不止!-CSDN博客_qtimer
[5] 利用PyQt GUI显示图片、实时播放视频 - JiangJ+ - 博客园
[6] python - How to play videos in pyqt - Stack Overflow

### PyQt5QTimer 的安装使用 #### 1. 安装 PyQt5 为了在 Python 环境中使用 PyQt5,需先通过 `pip` 工具完成安装。运行以下命令即可完成 PyQt5 的安装: ```bash pip install PyQt5 ``` 确认安装成功后,可以通过导入模块验证环境配置是否正常: ```python import PyQt5 print(PyQt5.__version__) ``` 如果上述代码能够顺利打印版本号,则说明 PyQt5 成功安装。 --- #### 2. QTimer 的基本概念 QTimerPyQt 提供的一个定时器类,允许开发设置时间间隔并触发特定的操作[^1]。它广泛应用于 GUI 应用程序中,例如周期性刷新界面数据、控制动画播放速度以及实现倒计时功能等[^3]。 --- #### 3. 创建和启动 QTimer 实例 以下是创建和使用 QTimer 的典型流程: - **引入必要的模块** 首先需要从 PyQt5.QtCore 导入 QTimer 类。 ```python from PyQt5.QtCore import QTimer ``` - **初始化 QTimer 对象** 实例化一个 QTimer 对象,并将其关联到目标窗口或对象上。 ```python timer = QTimer() ``` - **设定时间间隔** 调用 `setInterval()` 方法定义每次触发的时间间隔(单位为毫秒)。例如,每秒钟触发一次可写成如下形式: ```python timer.setInterval(1000) # 设置时间为 1 秒 (1000 毫秒) ``` - **连接信号槽函数** 当定时器超时时,会发出 `timeout()` 信号。因此,可通过 `connect()` 将该信号绑定至自定义的处理逻辑。 ```python def on_timeout(): print("定时器触发") timer.timeout.connect(on_timeout) ``` - **启动定时器** 最后调用 `start()` 启动定时器。 ```python timer.start() # 开始定时器 ``` 完整的示例代码如下所示: ```python from PyQt5.QtWidgets import QApplication, QLabel from PyQt5.QtCore import QTimer import sys class TimerExample(QLabel): def __init__(self): super().__init__() self.setText("等待定时器触发...") timer = QTimer(self) timer.setInterval(1000) # 设定每隔一秒触发 # 连接 timeout 信号到槽函数 timer.timeout.connect(self.update_text) timer.start() # 启动定时器 def update_text(self): current_text = int(self.text()) self.setText(str(current_text + 1)) if __name__ == "__main__": app = QApplication(sys.argv) window = TimerExample() window.resize(200, 100) window.show() sys.exit(app.exec_()) ``` 此代码展示了如何利用 QTimer 更新标签控件的内容,从而模拟简单的计数器应用。 --- #### 4. 处理多任务场景下的冲突问题 在某些复杂应用场景下,可能会涉及多个 QTimer 并发工作的情况。此时需要注意避免因资源竞争而导致的功能异常。例如,在同一位置动态显示不同的提示信息时,可能由于未及时清理旧消息而造成视觉混乱[^4]。 针对此类情况,建议采用以下策略之一加以改进: - 利用标志变量判断当前是否有正在展示的消息; - 或者借助额外的数据结构存储待处理的任务队列,并按顺序逐一执行。 具体实现方式取决于实际需求及业务逻辑设计。 ---
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

TracelessLe

❀点个赞加个关注再走吧❀

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值