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