下面的程序应该只计数和int,并在标签中显示它的值。但过了一段时间,GUI停止工作,同时循环继续。
from PyQt4 import QtGui,QtCore
import sys
class main_window(QtGui.QWidget):
def __init__(self,parent=None):
#Layout
QtGui.QWidget.__init__(self,parent)
self.bt=QtGui.QPushButton('crash')
self.lbl=QtGui.QLabel('count')
ver=QtGui.QHBoxLayout(self)
ver.addWidget(self.bt)
ver.addWidget(self.lbl)
self.cnt=0
self.running=False
self.connect(self.bt,QtCore.SIGNAL("clicked()"),self.count)
def count(self):
self.running=True
while self.running:
self.cnt+=1
print self.cnt
self.lbl.setText(str(self.cnt))
self.repaint()
if __name__ == '__main__':
app = QtGui.QApplication(sys.argv)
mw=main_window()
mw.show()
sys.exit(app.exec_()) 有什么帮助吗?
发布于 2009-12-21 04:21:20
def count(self):
self.running=True
while self.running:
self.cnt+=1
print self.cnt
self.lbl.setText(str(self.cnt))
self.repaint()你有没有想过从这个无休止的循环中退出?例如,self.running=False。
GUI可能会停止工作,因为它没有足够的时间执行repaint。您可能希望在循环中添加一些time.sleep,以等待图形用户界面重新绘制。
更新:对于你正在实现的行为,你应该使用QTimer,而不是简单的while循环。
发布于 2009-12-21 08:49:21
您没有让Qt的事件循环运行,所以GUI没有响应。此外,不需要repaint(),QLabel.setText()将重新绘制标签。它所做的就是排队一个额外的paint事件,但这个事件永远不会被处理。
您需要做的是用QtGui.QApplication.processEvents().替换self.repaint()这将使应用程序有机会处理任何挂起的事件(包括重绘,以及ui交互),而你在循环中。
发布于 2009-12-21 04:25:54
你必须让主事件循环运行,这是你没有做的事情。
https://stackoverflow.com/questions/1936868
复制相似问题