欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页

Android Q Go Apk热启动白屏/显示LOGO

程序员文章站 2022-04-20 20:06:18
...

问题点:

部分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热启动时间加快.