Brew 后台应用开发
翻译:牛阿牛
Overview 概述
Brew应用程序可以分为3类:激活的,挂起的和后台的;激活或挂起的应用程序驻留在应用程序栈里,这个栈是brew用来管理正在执行的应用的。栈中最上面(top)的是激活的应用程序,只有它才能直接与用户通过屏幕更换或者用户事件来交互信息;挂起应用某种程度上位于当前激活应用的栈下面
。
由于可能有多个应用处于挂起状态,开发者应该尽量保证挂起程序所占资源最小化。栈中的应用可以通过suspend 或resume 来挂起或激活应用。
在brew2.0版本中,涉及到了后台应用的开发。后台应用并不驻留在应用程序栈中;也就是说,它不会依据挂起或激活事件而改变运行状态。相反,后台应用一旦被初始化运行后,总是一直在运行中,而不受用户直接交户指令影响。
Starting/Ending 启动和结束
当开始初始化后台应用时,也像其他正常的brew应用一样;它可以直接由brew应用接口直接启动,也可以通过其他brew应用使用ISHELL_StartApplet函数来启动。
要将一个brew应用放入后台运行,brew应用在处理EVT_APP_STOP 事件时,必须将dwParam 的值设为false;这样在EVT_APP_STOP事件处理后,brew应用将被放在后台运行;后台应用要变为brew正常使用,必须通过自我运行ishell_StartApplet函数来激活应用本身。
由前所述可知,要终止一个后台应用将会比较困难,因为他们不能直接接受任何按键事件,因而,要结束一个后台应用就必须使用两种思路:后台应用成功执行完一个计划任务后终止自己或者通过其他独立的应用发送事件结束该后台应用。具体使用方法有如下三种:
其他应用通过ISHELL_SendEvent或ISHELL_PostEvent函数来发送事件(eCode 的值 大于evt_user)来通知后台应用结束;
后台应用在执行完制定任务后,通过ISHELL_CloseApplet函数来终止后台应用。根据api 的帮助说明,激活应用调用ISHELL_CloseApplet(pIShell,
TRUE)该参数的函数后,将会关闭所有正在执行的程序并且回到待机界面。然而,当由激活应用调用时,这个操作并不能影响到应用程序栈外面的程序;
应用通过调用ISHELL_StartApplet函数来激活自身,从而可以正常接受用户事件;
Suspend/Resume 挂起和恢复
由于后台应用驻留在应用程序栈的外面,因而他们不受挂起和恢复时间的影响。后台应用只有被激活才能处理挂起和恢复时间,它可以被自身或者其他程序发送的事件来激活。
Event Handling 事件处理
当后台应用正在运行时,它不能接受按键事件。然而很多后台应用可以使用事件处理来和其他激活应用交互,这样可以曲线控制后台应用。在这种情况下,激活应用可以通过ISHELL_SendEvent()or
ISHELL_PostEvent()方法来通知后台应用做出相应的反应。
Limitations 局限性
后台应用最主要的限制是除非自身激活,否则无法修改屏幕信息以及和用户直接交流。除此之外,开发者应该注重后台应用的运行环境的资源的有限性。这对于后台极为重要,由于可能有多个后台在同时运行。并且,运行后台应用的设备将需求更多的电源支持,有可能导致不能进入可信任模式;
因而,长期的后台应用,应该避免对设备电池寿命的有害影响。一些OEM厂商可能会限制后台运用的性能;例如:当运行后台运用时,它将不能使用socket或者不能播放铃音。
Examples 实例
Assume the following applet structure: //假设如下应用结构。
typedef struct _bgApp
{
AEEApplet a;
boolean m_bGoBg; // used to toggle whether to run in background mode,后台运用的标志状态。
} bgApp;
Model event handling for a background application: //后台运用的事件处理模型
switch (eCode)
{
case EVT_APP_START:
if(pMe->m_bGoBg)
ISHELL_CloseApplet(pMe->a.m_pIShell, FALSE); // send applet to background
return TRUE;
case EVT_APP_STOP:
if(pMe->m_bGoBg)
*((boolean*) dwParam) = FALSE; // set dwParam to run in bg ,后台运行了
return TRUE;
case EVT_USER:
if(pMe->m_bGoBg)
{
pMe->m_bGoBg = FALSE;
// make applet active,激活运用...
ISHELL_StartApplet(pMe->a.m_pIShell, AEECLSID_BGAPP); }
else
{
pMe->m_bGoBg = TRUE;
// trigger EVT_APP_STOP to send app to background
ISHELL_CloseApplet(pMe->a.m_pIShell, FALSE);
}
return TRUE;
}
应用程序可以通过evt_user 事件,可以将应用设置为后台应用或者激活应用;这些事件可以由其他应用通过ISHELL_SendEvent()
或者 ISHELL_PostEvent()函数来发送。在这个执行处理中,evt_user事件只是将应用本身在后台和前台之间作切换作用。更复杂的行为处理可以通过检测dwParam参数的值进行处理,这个值是由应用程序分发时间传递来的。如果应用程序直接由brew应用管理器启动,m_bGoBg的初始化值将决定是否在后台运行。