我做了一个可运行的示例来演示bug行为:http://pastebin.com/8KpzD4pw
这个问题非常严重。我在保存文件时打开了wx.ProgressDialog
,在IOError
之后,我想关闭进度对话框并显示一条错误消息。不幸的是,这似乎是不可能的。“进度”对话框公然拒绝在消息框关闭之前关闭:
如您所见,消息框出现在“进度”对话框的下方,因此用户必须手动将焦点切换到消息框以查看其内容。关闭消息框后,“进度”对话框也将消失。下面是save函数的代码:
def save(self, path=None):
# Show a loading dialog while the document is staving.
progress = shared.show_loading(self, 'Saving document')
try:
raise IOError('Error message')
if not path:
self.document.save()
else:
self.document.save_to_file(path)
except IOError as e:
progress.done()
message = 'Failed to save file:\n\n{}'.format(e.message)
wx.MessageBox(message, 'Error', wx.OK | wx.ICON_ERROR)
progress.done()
show_loading
和progress.done
函数只是使用wx.ProgressDialog
(source)的快捷方式。在
我还尝试使用wx.CallAfter
打开消息框,但没有成功:
我还试图在关闭进度对话框和使用wx.MicroSleep
打开消息框之间休眠100毫秒,但没有成功。在
我还尝试在销毁进度对话框后立即调用wx.Yield()
和wx.WakeUpIdle()
,但都没有任何效果。在
只是出于好奇。。。你试过用吗安全产量()或wx.产量()或wx.Yieldif需要()打电话给progressdialog.销毁()? 在
只是我在黑暗中拍摄的时候不太可能。在
我认为无限77有正确的答案。人们忘记了GUI调用不是同步的——它们在返回时还没有完成。“done”调用向窗口发送一条消息,作为响应,窗口可能会将多条消息排队进行清理。当您启动一个模型消息框时,它将创建自己的消息循环,而将原始消息循环保留在挂起的动画中。因此,在消息框返回并且主消息循环再次运行之前,无法处理清理消息。Yield调用将允许那些排队的消息排出。在
我有一个类似的案子,最后我打电话给他:
看起来,至少当你把进度对话框设置为“脉冲”模式时,它不会立即响应Destroy调用。在销毁它之前或之后,再多的睡眠或屈服都无法说服我的进度对话框停止显示。但是,通过简单地将值更新到最大值,它似乎会立即自动销毁(或至少隐藏)自身。在
相关问题 更多 >
编程相关推荐