Activity打开后被应用快照遮住的问题

为公司的银联二维码功能增加一个桌面快捷方式功能的时候,遇到一个头疼的问题,问题如下:

测试来回切换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 组件初始化完毕,从而成功销毁快照。

 

发布了161 篇原创文章 · 获赞 154 · 访问量 10万+

猜你喜欢

转载自blog.csdn.net/zhangying1994/article/details/104030994