MTK平台退出Screen的回调函数
接触MTK平台的人都知道MTK Application Screen的“入口”函数是EntryNewScreen,其中的一个参数为Exit Handler,根据字面意思的理解,这个函数应为退出Screen时的回调函数。
所以,一些有Win32开发经验的程序员很自然的想到利用这个回调函数来完成释放资源之类的处理,就如同Win32应用程序对WM_CLOSE消息的处理。
但是,这其实是个误区。
MTK的应用程序都是在OS的一个任务(MMI Task)内完成,其Screen组织方式也并非像Windows那样复杂,而只是简单的堆栈。形象一些,可以想象有一个浏览器窗口,没有前进只有后退按钮,从一个网页可以通过超链接打开别的网页,这些网页相互独立而并没有什么关系,当一个新的网页打开后,此前的网页就被暂时保存,用户可以通过后退的方法重新看到,MTK的窗口机制正是如此。
因此,MTK的Screen并不存在真正意思上的Close,也就是说,无论你是结束当前的界面返回上一层,或者在当前界面中进入别的界面,如通过左SoftKey进入名为“选项菜单”的界面,或者来了一则短信,弹出“通知”界面,Exit Handler都会被调用到。
那么有没有办法只在结束当前界面返回上一层时进行处理呢,MTK提供了另一个函数,这就是
U8 SetDelScrnIDCallbackHandler(U16 ScrnID, HistoryDelCBPtr funcPtr)
只有通过GoBackHistory等出栈的方法离开Screen,回调函数funcPtr才会被调用。
这样做,大大方便了我们程序的开发,但是,要注意,仍然不可将它与WM_CLOSE的动作相提并论,在开发MTK Application时,我们应抛弃原有的任务式应用程序的想法,以MTK的本来面目来审视之。