为公司的银联二维码功能增加一个桌面快捷方式功能的时候,遇到一个头疼的问题,问题如下:
测试来回切换app主界面的四个tab,然后点击home键,点击桌面快捷方式,概率性出现银联二维码界面被主界面快照遮盖。
现象(银联二维码界面被主界面快照遮盖后):
1.进入最近任务栏,发现最近任务栏中的快照也是主界面的Activity, 也是错误的。
2.通过adb查看任务栈信息,发现任务栈信息是正常的,银联二维码界面确实是在HomeActivity上面的,只是被应用快照遮住了。
3.页面点击事件
响应的是银联二维码页面的点击事件。
4.页面进入后台,重新打开
onStop- onRestart- onStart- onResume 银联二维码页面恢复。
为什么会有快照?
在Activity启动的前期准备阶段,会借助PMS,确认需要启动的Activity,并对intent、权限等进行验证,同时根据launcheMode和flag配置 task,这时候通过加载快照(预览窗口)进行过渡,提升用户体验。
当按下home键, framework会存下一个应用的快照,快照可以通过taskId获取,当应用从后台进入前台时,会先显示快照,再开始执行当前Activity的生命周期方法。 在执行ActivityStack执行startActivityLocked的时候,通过ActivityRecord的showStartingWindow方法开始正式进入starting window的显示流程。
当然跳转到银联二维码的方式是调用基础封装的方法。
问题原因:
快照销毁失败。 应用进入前台触发了绘制快照,但是销毁快照失败了。
ActivityStack.java
最终修改方案:
对跳转到银联二维码界面的跳转方法延时500毫秒,保证主界面HomeActivity 组件初始化完毕,从而成功销毁快照。
以上就是本文的全部内容,希望对大家的学习有所帮助。