PyQt5多线程刷新界面防假死示例
在做GUI界面时我们希望后台任务能够与UI分开,在PyQt中,主线程用来重绘界面。而子线程里边的实时处理结果需要反馈到界面,子线程里边不能执行界面更新操作。
wxpython多线程刷新界面转到
https://www.nhooo.com/article/176308.htm
下面给出类Python3+PyQt5多线程防假死动态刷新界面的模板
fromPyQt5importQtWidgets,QtCore importsys fromPyQt5.QtCoreimport* importtime #继承QThread classRunthread(QtCore.QThread): #通过类成员对象定义信号对象 _signal=pyqtSignal(str) def__init__(self): super(Runthread,self).__init__() def__del__(self): self.wait() defrun(self): foriinrange(100): time.sleep(0.2) self._signal.emit(str(i))#注意这里与_signal=pyqtSignal(str)中的类型相同 classExample(QtWidgets.QWidget): def__init__(self): super().__init__() #按钮初始化 self.button=QtWidgets.QPushButton('开始',self) self.button.setToolTip('这是一个QPushButtonwidget') self.button.resize(self.button.sizeHint()) self.button.move(120,80) self.button.clicked.connect(self.start_login)#绑定多线程触发事件 #进度条设置 self.pbar=QtWidgets.QProgressBar(self) self.pbar.setGeometry(50,50,210,25) self.pbar.setValue(0) #窗口初始化 self.setGeometry(300,300,300,200) self.setWindowTitle('OmegaXYZ.com') self.show() self.thread=None#初始化线程 defstart_login(self): #创建线程 self.thread=Runthread() #连接信号 self.thread._signal.connect(self.call_backlog)#进程连接回传到GUI的事件 #开始线程 self.thread.start() defcall_backlog(self,msg): self.pbar.setValue(int(msg))#将线程的参数传入进度条 if__name__=="__main__": app=QtWidgets.QApplication(sys.argv) myshow=Example() myshow.show() sys.exit(app.exec_())
效果:
以上这篇PyQt5多线程刷新界面防假死示例就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持毛票票。
声明:本文内容来源于网络,版权归原作者所有,内容由互联网用户自发贡献自行上传,本网站不拥有所有权,未作人工编辑处理,也不承担相关法律责任。如果您发现有涉嫌版权的内容,欢迎发送邮件至:czq8825#qq.com(发邮件时,请将#更换为@)进行举报,并提供相关证据,一经查实,本站将立刻删除涉嫌侵权内容。