Android編程之自訂鎖屏執行個體分析_Android

來源:互聯網
上載者:User

本文執行個體講述了Android編程之自訂鎖屏。分享給大家供大家參考,具體如下:

花了半天時間研究下了自訂鎖屏,發現其實實現並不是很神秘。不過有些地方還是值得注意。

首先說流程,鎖定畫面一般是在關閉螢幕時啟用,開啟螢幕時展現在我們面前,所以我們知道了鎖屏的時機,恰好螢幕開關會發出相應的廣播,所以我們也可以像系統一樣捕獲到螢幕開關的事件。

廣播對應的兩個action

引用

android.intent.action.SCREEN_ONandroid.intent.action.SCREEN_OFF

有趣的是我在我的me860上還看到了兩個廣播

引用

android.intent.action.batteryprofile.SCR_OFFandroid.intent.action.batteryprofile.SCR_ON

這可能是moto自己定義的廣播,看大家需要了。

如果單單只截獲到廣播,鎖屏的介面怎麼替換系統鎖屏呢?其實我們這裡並沒有替換掉系統鎖屏,只是我們自己的鎖屏開啟了系統鎖屏,從而達到了一個替換的效果。

這裡還是要注意點,上述action不能在AndroidManifest.xml中註冊,不能觸發。所以這裡我採用的方法是放在一個service中動態註冊,截獲廣播正常。

這裡還順帶提下service防殺的功能,因為service的進程如果不存在了,那麼螢幕開關的廣播是無論如何也接收不到的。

如果是系統回收掉的service,系統會在過段時間,資源充足的情況下再啟動起來,不過我們可不想自己的service坐冷板凳,所以對付系統關閉service我們採取如下方法。

在service生命週期中:

Intent startIntent=null;@Override public void onStart(Intent intent, int startId) {  startIntent=intent;  IntentFilter filter=new IntentFilter();  filter.addAction(Intent.ACTION_SCREEN_ON);  filter.addAction(Intent.ACTION_SCREEN_OFF);  receiver=new RelativeBroadcastReceiver();  registerReceiver(receiver, filter);  System.out.println("service onStart and action is "+intent.getAction());  System.out.println("service onStart and startId is "+startId); }; @Override public void onDestroy() {  // TODO Auto-generated method stub  System.out.println("service onDestroy");  unregisterReceiver(receiver);  if(startIntent!=null){   System.out.println("serviceIntent not null");   startService(startIntent);  }

我們保留了開啟service的intent,當進入ondestroy周期中時再啟動一次自己,系統看到你這勁頭也只好答應你常駐記憶體了。

不過如果是一些記憶體管理軟體殺掉了程式進程,以上方法就沒用了,我們還是可以通過截獲一些關鍵廣播來啟動自己的service,類似91助手等就是這樣。可以監聽wifi串連,電池電量發生變化等廣播來啟動自己的service。

保證自己的service常駐,這時候就該我們自己的廣播接收器發揮作用了。

@Override public void onReceive(Context context, Intent intent) {  // TODO Auto-generated method stub  String action=intent.getAction();  System.out.println("action is "+action);  Intent lockIntent=new Intent(context,MyLockScreen.class);  lockIntent.addFlags(Intent.FLAG_ACTIVITY_NEW_TASK);  context.startActivity(lockIntent);}

需要加上lockIntent.addFlags(Intent.FLAG_ACTIVITY_NEW_TASK);沒有加的時候系統會報錯,但是加上以後也有問題,這會導致多次退出才能退出自訂的鎖定畫面。
其實可以自訂一個stack來管理這些activity,有其他辦法的同學請提示我改正。

啟動了一個activity以後我們發現還是原來的鎖定畫面,這也是前面提到的,我們的鎖屏需要開啟系統鎖屏。
開啟系統鎖屏:

super.onCreate(savedInstanceState);getWindow().addFlags(WindowManager.LayoutParams.FLAG_SHOW_WHEN_LOCKED);getWindow().addFlags(WindowManager.LayoutParams.FLAG_DISMISS_KEYGUARD);setContentView(R.layout.main);

添加了這兩個flag以後,系統鎖屏就被替換成了我們自己的鎖定畫面。

鎖屏替換功能也就完成了。其實還可以修改系統鎖屏,不過設計到架構層的修改,推廣也很麻煩,所以掠過不說了。

希望本文所述對大家Android程式設計有所協助。

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.