去年年底曾经弄过一段时间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,但愿我说明白了~