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 組件初始化完畢,從而成功銷燬快照。

 

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章