2.4 如何关闭wxPython应用程序?

当你的应用程序的最后的顶级窗口被用户关闭时, wxPython应用程序就退出了。我们这里所说的顶层窗口是指任何没有父亲的框架,并不只是使用SetTopWindow()方法设计的框架。这包括任 何由wxPython自身创建的框架。在我们重定向的例子中,wxPython应用程序在主框架和输出重定向的框架都被关闭后退出,仅管只有主框架是使用 SetTopWindow()登记的,尽管应用程序没有明确地创建这个输出重定向框架。要使用编程触发一个关闭,你可以在所有的这里所谓顶级窗口上调用 Close()方法。

2.4.1 管理正常的关闭

在关闭的过程期间, wxPython关心的是删除所有的它的窗口和释放它们的资源。你可以在退出过程中定义一个钩子来执行你自己的清理工作。由于你的wx.App子类的 OnExit()方法在最后一个窗口被关闭后且在wxPython的内在的清理过程之前被调用,你可以使用OnExit()方法来清理你创建的任何非 wxPython资源(例如一个数据库连接)。即使使用了wx.Exit()来关闭wxPython程序,OnExit()方法仍将被触发。

如 果由于某种原因你想在最后的窗口被关闭后wxPython应用程序仍然可以继续,你可以使用wx.App的SetExitOnFrameDelete (flag)方法来改变默认的行为。如果flag参数设置为False,那么最后的窗口被关闭后wxPython应用程序仍然会继续运行。这意味着 wx.App实例将继续存活,并且事件循环将继续处理事件,比如这时你还可以创建所有新的这里所谓的顶级窗口。wxPython应用程序将保持存活直到全 局函数wx.Exit()被明确地调用。

2.4.2 管理紧急关闭

你不能总是以一个可控的方法关闭你的程序。有时候,你需要立即结束应用程序并不考虑清理工作。例如一个必不可少的资源可能已被关闭或被损坏。如果系统正在关闭,你可能不能做所有的清理工作。

这 里有两种在紧急情况下退出你的wxPython应用程序的方法。你可以调用wx.App的ExitMainLoop()方法。这个方法显式地使用主消息循 环终止,使用控制离开MainLoop()函数。这通常将终止应用程序,这个方法实际上等同于关闭所有这里所谓顶级窗口。

你也可以调用全局方法wx.Exit()。正常使用情况下,两种方法我们都不推荐,因为它将导致一些清理函数被跳过。

有 时候,你的应用程序由于一个控制之外的事件而需要关闭。例如操作系统的关闭或注销。在这种情况下,你的应用程序将试图做一些保存文档或关闭连接等等。如果 你的应用程序为wx.EVT_QUERY_END_SESSION事件绑定了一个事件处理器,那么当wxPython得到关闭通知时这个事件处理器将被调 用。这个event参数是wx.CloseEvent。我们可以通过关闭事件来否决关闭。这可以使用关闭事件的CanVeto()方法,CanVeto ()方法决定是否可以否决,Veto()执行否决。如果你不能成功地保存或关闭所有的资源,你可能想使用该方法。 wx.EVT_QUERY_END_SESSION事件的默认处理器调用顶级窗口的Close()方法,这将依次向顶层窗口发送wx.EVT_CLOSE 事件,这给了你控制关闭过程的另一选择。如果任何一个Close()方法返回False,那么应用程序将试图否决关闭。