Android Q Go Apk热启动白屏/显示LOGO
问题点:
部分apk热启动会显示一下白屏/LOGO,导致apk热启动比对比机慢.
分析:
拍摄apk(日历或者设置apk)的热启动过程.慢动作播放,可以明显的看到apk启动过程中先显示白屏/LOGO.而对比机则没有这一过程.
一般情况下,只有冷启动会显示白屏或者LOGO,用LOGO图片掩盖白屏.而热启动直接加载apk界面,不会显示白屏或者LOGO.
可能原因:
1.查看log未发现异常.
2.在app info里面,apk的Storage & cache与对比机没有差异.
3.在开发者模式中有一个选项:Don't keep activites.当你离开一个Activity的时候.Activity的生命周期就不是像之前那样处于OnStop状态了,它会进入OnDestroy状态被系统销毁回收掉。热启动时,重新加载界面.类似这种情况,但是我们的并未打开这个测试项.故排除.
继续分析,apk显示白屏或者LOGO的原因:
在Activity启动的时候,Android系统会为它添加一个启动窗口,作用是在应用程序主Activity还没有显示出来的时候(加载数据和资源需要时间),它作为一个预览窗口先让用户能看到一个画面,起到缓冲的作用,同时用户体验会更好.
热启动直接显示界面的原因:当你的Activity启动过一次,那么就有TaskSnapshop存在系统中,当你热启动的时候,创建启动窗口,然后窗口显示的内容不是白屏,也不是LOGO,而是TaskSnapshop.这样子就会直接显示activity了.
那么这个问题应该是TaskSnapshop不存在或者不显示了.
系统给定三种类型的启动窗口:
STARTING_WINDOW_TYPE_NONE:不添加starting window
STARTING_WINDOW_TYPE_SNAPSHOT:使用任务快照作为starting window的显示内容(热启动)
STARTING_WINDOW_TYPE_SPLASH_SCREEN:默认行为,该界面显示的内容搜应用主题相关属性设置的影响
从这一点出发,找到GMS有一个配置项:
overlay/frameworks/base/core/res/res/values/config.xml:
<!-- Enable .1x scale snapshots.-->
<bool name="config_lowRamTaskSnapshotsAndRecents">true</bool>
是跟TaskSnapshots相关的,查看代码:
getStartingWindowType(){
} else if (newTask || !processRunning || (taskSwitch && !activityCreated)) { return STARTING_WINDOW_TYPE_SPLASH_SCREEN; //此此Activity的task和启动它的Activity不在同一个task //并且允许创建任务快照窗口 } else if (taskSwitch && allowTaskSnapshot) { if (mWmService.mLowRamTaskSnapshotsAndRecents) { //在低RAM设备上使用启动窗口代替 //任务快照窗口。 return STARTING_WINDOW_TYPE_SPLASH_SCREEN; } //这里是使用任务快照窗口还是启动窗口的一些条件判断 return snapshot == null ? STARTING_WINDOW_TYPE_NONE : snapshotOrientationSameAsTask(snapshot) || fromRecents ? STARTING_WINDOW_TYPE_SNAPSHOT : STARTING_WINDOW_TYPE_SPLASH_SCREEN; }
}
从这里我们可以看到
mWmService.mLowRamTaskSnapshotsAndRecents与
一个新task启动,或者此Activity所在的进程还未运行,或者(此Activity的task和启动它的Activity不在同一个task并且此Activity还为创建),满足其中一个条件说明需要启动窗口.
是一样的.
修改<bool name="config_lowRamTaskSnapshotsAndRecents">true</bool>为fail,热启动白屏或者显示LOGO界面的现象不存在,apk热启动时间加快.
上一篇: POJ ACM习题【No.3325】
下一篇: 正则的应用(更新ing)