NativeApplication.nativeApplication.addEventListener(Event.CLOSING,onAppExitHandler);//程序退出时关闭通信
参考: http://help.adobe.com/zh_CN/AIR/1.1/devappsflex/WS5b3ccc516d4fbf351e63e3d118676a5d46-8000.html
应用程序终止
终止应用程序最快的方法是调用 NativeApplication.nativeApplication.exit(),在应用程序没有要保存的数据或要清空的资源时该方法最佳。调用exit() 将关闭所有窗口,然后终止该应用程序。但是,若要允许窗口或应用程序的其他组件中断该终止进程(也许要保存重要数据),请在调用 exit() 之前调度适当的警告事件。
另一种妥善关闭应用程序的方法是提供单一执行路径,而不考虑关闭进程的启动方式。用户(或操作系统)可以通过以下方式触发应用程序终止:
-
在 NativeApplication.nativeApplication.autoExit 为 true 的情况下关闭最后一个应用程序窗口。
-
从操作系统中选择应用程序退出命令;例如,用户从默认菜单中选择退出应用程序命令。这仅适用于 Mac OS;Windows 不通过系统镶边提供应用程序退出命令。
-
关闭计算机。
当采用上述方式之一通过操作系统执行退出命令时,NativeApplication 将调度 exiting 事件。如果没有侦听器取消 exiting 事件,则任何打开的窗口都将关闭。每个窗口都会先调度一个 closing 事件,然后调度一个 close 事件。如果任何窗口取消 closing 事件,则关闭进程将会停止。
如果需要考虑应用程序的窗口关闭顺序,则可侦听来自 NativeApplication 的 exiting 事件并自行决定以适当的顺序关闭窗口。这种情况可能存在,例如,如果某个文档窗口具有工具调板时。如果系统关闭了调板而用户却决定取消退出命令以保存某些数据,这可能会带来不便,甚至更糟糕的情形。在 Windows 中,收到 exiting 事件的唯一时间是在关闭最后一个窗口之后(当 NativeApplication 对象的 autoExit 属性设置为 true 时)。
若要在所有平台上提供一致的行为,而不考虑退出顺序是通过操作系统镶边、菜单命令还是通过应用程序逻辑启动的,请遵守用于退出应用程序的以下良好做法:
-
始终先通过 NativeApplication 对象调度 exiting 事件,然后再调用应用程序代码中的 exit() 并检查应用程序的其他组件是否没有取消该事件。
public function applicationExit():void { var exitingEvent:Event = new Event(Event.EXITING, false, true); NativeApplication.nativeApplication.dispatchEvent(exitingEvent); if (!exitingEvent.isDefaultPrevented()) { NativeApplication.nativeApplication.exit(); } }
-
侦听来自 NativeApplication.nativeApplication 对象的应用程序 exiting 事件,并在处理函数中关闭任何窗口(首先调度 closing 事件)。在所有窗口都已关闭后执行任何所需的清理任务,例如保存应用程序数据或删除临时文件。在清理期间仅使用同步方法以确保在应用程序退出之前能完成清理任务。
如果窗口关闭的顺序无关紧要,则可以遍历 NativeApplication.nativeApplication.openedWindows 数组并依次关闭每个窗口。如果顺序的确 很重要,则需提供一种以正确顺序关闭窗口的方法。
private function onExiting(exitingEvent:Event):void { var winClosingEvent:Event; for each (var win:NativeWindow in NativeApplication.nativeApplication.openedWindows) { winClosingEvent = new Event(Event.CLOSING,false,true); win.dispatchEvent(winClosingEvent); if (!winClosingEvent.isDefaultPrevented()) { win.close(); } else { exitingEvent.preventDefault(); } } if (!exitingEvent.isDefaultPrevented()) { //perform cleanup } }
-
Windows 应始终通过侦听自己的 closing 事件来处理自己的清理任务。
-
在应用程序中仅使用一个 exiting 侦听器,因为调用时间较早的处理函数无法知道随后的处理函数是否将取消 exiting 事件(依赖于执行顺序将是不明智的做法)。