Android 2.3原生Launcher2的一个问题

在Android 2.3版本中,原生Launcher2存在一个问题:当从菜单进入应用程序管理并清除数据或停止后,每次点击Home键都会创建新的桌面。原因是启动应用程序管理Activity时未添加FLAG_ACTIVITY_NEW_TASK标志。分析表明,由于Launcher的singleTask模式和clearTaskOnLaunch属性,导致了活动的反复创建和销毁。解决方案是确保singleTask模式的Activity作为Task的根Activity,或调整clearTaskOnLaunch设置。

      去年年底曾经弄过一段时间Launcher,当时是定制一个Android桌面,主要是模仿三星的TouchWiz界面,由于和原生桌面差别不是很大,主要还是做了些界面的研究和修改,并没有深入Launcher的具体细节。最近偶尔发现了一个原生Launcher的BUG,又重新开始研究Launcher,不多说,先上bug:

      版本:2.3

      步骤:1. 运行原生Launcher2

               2. Menu -> 应用程序管理 -> 选中原生Launcher2 ->清除数据或者强行停止

               3. Home键返回桌面

               此时问题出来了:此后每次点击Home键可以发现每次都会重新创建新的桌面(一个明显的界面切换),有兴趣的话可以亲自试试~

 

       我们知道Launcher的LauncherMode是singleTask,也就是说它是一个单例模式,在该Task中只有一个实例,为何会重新创建实例呢?我们先来看看引起整个问题的Menu -> 应用程序管理的代码:

       private void manageApps() {
             startActivity(new Intent(android.provider.Settings.ACTION_MANAGE_ALL_APPLICATIONS_SETTINGS));
       }

       这是2.3的Laucnher2新增的一个Menu入口,这里启动Activity的Flag并没有遵照约定加上FLAG_ACTIVITY_NEW_TASK,我们可以先猜测就是这个引起的问题,试试加上这个Flag,编译,运行,哈,果然问题解决~

      可是这是为什么呢?我们再来分析一下这个问题产生的过程,在分析之前首先你需要了解Task,Activity的配置参数(例如launcherMode及clearTaskOnLaunch)以及Intent的Flag,具体可以参考google官方文档,下面开始分析:

       1. 运行Launcher2。 Task: Launcher

       2. Menu -> 应用程序管理。 Task: Launcher -> Application Settings。 分析:由于拉起这个Activity未加NEW_TASK的Flag,应用程序管理的Activity加入到Launcher同一个Task中。

       3. 选中原生Launcher2 -> 清除数据或者强行停止。Task:Application Settings。分析:Launcher被迫结束,从Task中移除。

       4. 点击Home键。Task:Application Settings -> Launcher。分析:Launcher的 launcherMode为singleTask, 此时其Task已经存在,不会创建新的Task而是放入已存在的Task中,即Application Settings -> Launcher。

       5. Launcher显示。 Task:Application Settings。分析:Launcher的clearTaskOnLaunch为true,会清除Task中除root之外的所有Activity,刚加进去的Launcher马上又从Task中移除。4 -> 5 如此往复, 也就是上面说的问题了。为了证明确实是这个原因,你可以把clearTaskOnLaunch设置为false试试。

       综上所述,问题其实就是singleTask的Activity并不是Task中的root Activity,但愿我说明白了~

评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值