我已经从一个小应用程序中删除了内容以证明这种行为。在osx下,这符合我的预期:当您按下按钮时,它会打印“Asked to start work”,然后会出现一个消息框,并且按下OK按钮后会暂停,然后开始打印“让步”并且GUI保持适度活跃。
import wx
import time
class MainWindow(wx.Frame):
def __init__(self, parent, id, title):
wx.Frame.__init__(self, parent, id, title, size=(800, 700))
self.tabbed = wx.Notebook(self, -1, style=(wx.NB_TOP))
self.running = RunningPane(self.tabbed)
self.submissions = SubmissionPane(self.tabbed, self.running)
self.tabbed.AddPage(self.submissions, "Submit Job")
self.tabbed.AddPage(self.running, "Running Jobs")
self.Show()
class SubmissionPane(wx.Panel):
def __init__(self, parent, run_pane):
wx.Panel.__init__(self, parent, -1)
self.run_pane = run_pane
self.buttonGo = wx.Button(self, -1, "Submit", pos=(290,170))
self.buttonGo.Bind(wx.EVT_BUTTON, self.OnSubmit)
self.Show()
def OnSubmit(self, event):
self.run_pane.StartWork()
print "requested work start"
wx.MessageBox('Job Submitted')
print "displayed message box"
class RunningPane(wx.Panel):
def __init__(self, parent):
wx.Panel.__init__(self, parent, -1)
self.running_log = wx.TextCtrl(self, -1, pos=(35, 210), size=(720,400))
self.Show()
def StartWork(self):
print "Asked to Start Work..."
wx.CallAfter(self.DoTheWork)
print "registered the CallAfter"
def DoTheWork(self):
print "Actually starting work"
self.running_log.WriteText("doing..."+"\n")
for i in range(20):
print "yielding"
wx.Yield()
time.sleep(1)
print "I pretended to do the work :) "
app = wx.App()
MainWindow(None, -1, 'Application')
app.MainLoop()
但是,在Windows下,对话框直到打印完20个后才出现 - 按下按钮后立即开始 - 并且GUI在此期间没有响应。
我是否误解了wx.Yield()
会发生什么?
答案 0 :(得分:3)
您必须记住,wxPython在每个操作系统上包装本机小部件。如果本机窗口小部件在Windows上的行为与在Linux或Mac上的行为不同,那么对于该操作系统来说实际上可能是正常的。我猜这就是这里发生的事情。一个简单的解决方法是切换到可以模态显示的wx.MessageDialog。因此,使用以下两个替换创建wx.MessageBox的行:
msg = wx.MessageDialog(self, 'Job Submitted', "Job", wx.OK)
msg.ShowModal()