android-AlarmService的使用

可參考博客:http://blog.csdn.net/knxw0001/article/details/10180397

2.1通過AlarmService每個5秒發送一個廣播,setRepeating時的類型爲AlarmManager.ELAPSED_REALTIME。 


AlarmManager am = (AlarmManager)getSystemService(ALARM_SERVICE);  

am.setRepeating(AlarmManager.ELAPSED_REALTIME, firstTime,5*1000, sender);

拔掉USB線,按下電源鍵,過一段時間再次打開屏幕,發現定時器沒有繼續計數。 
2.2setRepeating是的類型設置爲AlarmManager.ELAPSED_REALTIME_WAKEUP 


AlarmManager am = (AlarmManager)getSystemService(ALARM_SERVICE);   

am.setRepeating(AlarmManager.ELAPSED_REALTIME_WAKEUP, firstTime,5*1000, sender);

拔掉USB線,按下電源鍵,過一點時間再次打開屏幕,發現定時器一直在計數。 

如此看來,使用WAKEUP才能保證自己想要的定時器一直工作,但是肯定會引起耗電量的增加

AlarmManager的使用機制有的稱呼爲全局定時器,有的稱呼爲鬧鐘。通過對它的使用,個人覺得叫全局定時器比較合適,其實它的作用和Timer有點相似。都有兩種相似的用法:(1)在指定時長後執行某項操作(2)週期性的執行某項操作

AlarmManager對象配合Intent使用,可以定時的開啓一個Activity,發送一個BroadCast,或者開啓一個Service.

下面的代碼詳細的介紹了兩種定時方式的使用:

 (1)在指定時長後執行某項操作

 

Java代碼  收藏代碼
  1.      //操作:發送一個廣播,廣播接收後Toast提示定時操作完成  
  2. <!--  
  3.   
  4. Code highlighting produced by Actipro CodeHighlighter (freeware)  
  5. http://www.CodeHighlighter.com/  
  6.   
  7. -->     Intent intent =new Intent(Main.this, alarmreceiver.class);  
  8.     intent.setAction("short");  
  9.     PendingIntent sender=  
  10.         PendingIntent.getBroadcast(Main.this0, intent, 0);  
  11.       
  12.     //設定一個五秒後的時間  
  13.     Calendar calendar=Calendar.getInstance();  
  14.     calendar.setTimeInMillis(System.currentTimeMillis());  
  15.     calendar.add(Calendar.SECOND, 5);  
  16.       
  17.     AlarmManager alarm=(AlarmManager)getSystemService(ALARM_SERVICE);  
  18.     alarm.set(AlarmManager.RTC_WAKEUP, calendar.getTimeInMillis(), sender);  
  19.     //或者以下面方式簡化  
  20.     //alarm.set(AlarmManager.RTC_WAKEUP, System.currentTimeMillis()+5*1000, sender);  
  21.       
  22.     Toast.makeText(Main.this"五秒後alarm開啓", Toast.LENGTH_LONG).show();  
 

//注意:receiver記得在manifest.xml註冊


Java代碼  收藏代碼
  1. <!--  
  2.   
  3. Code highlighting produced by Actipro CodeHighlighter (freeware)  
  4. http://www.CodeHighlighter.com/  
  5.   
  6. -->    public static class alarmreceiver extends BroadcastReceiver{  
  7.   
  8.         @Override  
  9.         public void onReceive(Context context, Intent intent) {  
  10.             // TODO Auto-generated method stub  
  11.             if(intent.getAction().equals("short")){  
  12.                 Toast.makeText(context, "short alarm", Toast.LENGTH_LONG).show();  
  13.             }else{  
  14.                 Toast.makeText(context, "repeating alarm",   
  15.                       Toast.LENGTH_LONG).show();  
  16.             }  
  17.         }  
  18.     }  
 

(2)週期性的執行某項操作

Java代碼  收藏代碼
  1. <!--  
  2.   
  3. Code highlighting produced by Actipro CodeHighlighter (freeware)  
  4. http://www.CodeHighlighter.com/  
  5.   
  6. -->    Intent intent =new Intent(Main.this, alarmreceiver.class);  
  7.     intent.setAction("repeating");  
  8.     PendingIntent sender=PendingIntent  
  9.         .getBroadcast(Main.this0, intent, 0);  
  10.       
  11.   
  12.     //開始時間  
  13.     long firstime=SystemClock.elapsedRealtime();  
  14.   
  15.     AlarmManager am=(AlarmManager)getSystemService(ALARM_SERVICE);  
  16.   
  17.   //5秒一個週期,不停的發送廣播  
  18.     am.setRepeating(AlarmManager.ELAPSED_REALTIME_WAKEUP  
  19.             , firstime, 5*1000, sender);  
 

 AlarmManager的setRepeating()相當於Timer的Schedule(task,delay,peroid);有點差異的地方時Timer這個方法是指定延遲多長時間

以後開始週期性的執行task;

AlarmManager的取消:(其中需要注意的是取消的Intent必須與啓動Intent保持絕對一致才能支持取消AlarmManager)

 

 

Java代碼  收藏代碼
  1. <!--  
  2.   
  3. Code highlighting produced by Actipro CodeHighlighter (freeware)  
  4. http://www.CodeHighlighter.com/  
  5.   
  6. -->  Intent intent =new Intent(Main.this, alarmreceiver.class);  
  7.   intent.setAction("repeating");  
  8.   PendingIntent sender=PendingIntent  
  9.          .getBroadcast(Main.this0, intent, 0);  
  10.   AlarmManager alarm=(AlarmManager)getSystemService(ALARM_SERVICE);  
  11.   alarm.cancel(sender);  
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章