標籤:android android開發 broadcastreceiver launcher 非同步
Android的TV監聽Home鍵切換信源碰到的問題
實現的功能是按下Home鍵,焦點放到TV小視窗上,再次按下Home鍵,切換信源,進入另一個信源。在另一個信源的顯示下,按下Home鍵,原信源視圖縮小並顯示當前信源。
這個需求的解決代碼比較容易的。實現一個BroadCastReceiver,監聽Home鍵。但是依照HOME鍵的實現的時候,系統會切換到當前Launcher,因此,在當前信源的情況下點擊HOME鍵,走的流程是:
onPause->onStop->onRestart->onStart->onResume。
這是暴露給我們能夠複寫的函數,但是這裡其實隱藏了一個很重要的細節。執行到onRsume的時候,系統應該是非同步切換Avtivity的View,即顯示當前預設Launcher的View。因此在切換信源的時候,這個時間周期同步就可能出現問題。即,當焦點在TV小視窗的時候按下Home鍵
①android系統切換到當前Launcher,
②切換信源,進入TV。
或者②——>①,不能進入TV。這時候當前的Launcher的View不會重繪,因此完全看不出來是已經切換了信源,又切回來的這麼個過程。
之前一直有在各個周期函數中寫下Log,檢查無異樣(所以據此猜測是非同步執行View的重繪)。然後查看整個android系統的Log。在命令列中重新導向:
adb logcat -v -f time > f:\adblocat.txt。
以此來查看整個系統的log,發現在ActivityManager中有一次切換到當前的Launcher,因此解決這個問題。方法很簡單,就是在BroadCastReceiver中新開線程並sleep一小段時間來強制系統切換Launcher在前,轉換信源在後(即①——>②),這樣便ok了。
總結,在多應用(信源)切換的時候,外接應用(jar)較多的時候要多看系統的log,已檢視問題的所在。瞭解核心控制項,事件的時候要相對深刻一點,盡量去思考實現機制,以便查處問題的所在!
監聽Android的Home鍵碰到的問題