|
9Alarm是在預(yù)定的時(shí)間上觸發(fā)Intent的一種獨(dú)立的方法。
Alarm超出了應(yīng)用程序的作用域,所以它們可以用于觸發(fā)應(yīng)用程序事件或動(dòng)作,甚至在應(yīng)用程序關(guān)閉之后。與Broadcast Receiver結(jié)合,它們可以變得尤其的強(qiáng)大,可以通過設(shè)置Alarm來啟動(dòng)應(yīng)用程序或者執(zhí)行動(dòng)作,而應(yīng)用程序不需要打開或者處于活躍狀態(tài)。
舉個(gè)例子,你可以使用Alarm來實(shí)現(xiàn)一個(gè)鬧鐘程序,執(zhí)行正常的網(wǎng)絡(luò)查詢,或者在“非高峰”時(shí)間安排耗時(shí)或有代價(jià)的操作。
對于僅在應(yīng)用程序生命周期內(nèi)發(fā)生的定時(shí)操作,Handler類與Timer和Thread類的結(jié)合是一個(gè)更好的選擇,它允許Android更好地控制系統(tǒng)資源。
Android中的Alarm在設(shè)備處于睡眠模式時(shí)仍保持活躍,它可以設(shè)置來喚醒設(shè)備;然而,所有的Alarm在設(shè)備重啟時(shí)都會(huì)被取消。
Alarm的操作通過AlarmManager來處理,通過getSystemService可以獲得其系統(tǒng)服務(wù),如下所示:
AlarmManager alarms = (AlarmManager)getSystemService(Context.ALARM_SERVICE);
為了創(chuàng)建一個(gè)新的Alarm,使用set方法并指定一個(gè)Alarm類型、觸發(fā)時(shí)間和在Alarm觸發(fā)時(shí)要調(diào)用的Intent。如果你設(shè)定的Alarm發(fā)生在過去,那么,它將立即觸發(fā)。
這里有4種Alarm類型。你的選擇將決定你在set方法中傳遞的時(shí)間值代表什么,是特定的時(shí)間或者是時(shí)間流逝:
在指定的時(shí)刻(設(shè)置Alarm的時(shí)候),喚醒設(shè)備來觸發(fā)Intent。
在一個(gè)顯式的時(shí)間觸發(fā)Intent,但不喚醒設(shè)備。
從設(shè)備啟動(dòng)后,如果流逝的時(shí)間達(dá)到總時(shí)間,那么觸發(fā)Intent,但不喚醒設(shè)備。流逝的時(shí)間包括設(shè)備睡眠的任何時(shí)間。注意一點(diǎn)的是,時(shí)間流逝的計(jì)算點(diǎn)是自從它最后一次啟動(dòng)算起。
從設(shè)備啟動(dòng)后,達(dá)到流逝的總時(shí)間后,如果需要將喚醒設(shè)備并觸發(fā)Intent。
Alarm的創(chuàng)建過程演示如下片段所示:
- int alarmType = AlarmManager.ELAPSED_REALTIME_WAKEUP;
long timeOrLengthofWait = 10000;
String ALARM_ACTION = “ALARM_ACTION”;
Intent intentToFire = new Intent(ALARM_ACTION);
PendingIntent pendingIntent = PendingIntent.getBroadcast(this, 0, intentToFire, 0);
alarms.set(alarmType, timeOrLengthofWait, pendingIntent);
復(fù)制代碼 當(dāng)Alarm到達(dá)時(shí),你指定的PendingIntent將被觸發(fā)。設(shè)置另外一個(gè)Alarm并使用相同的PendingIntent來替代之前存在的Alarm。
取消一個(gè)Alarm,調(diào)用AlarmManager的cancel方法,傳入你不再希望被觸發(fā)的PendingIntent,如下面的代碼所示:
接下來的代碼片段中,設(shè)置了兩個(gè)Alarm,隨后馬上取消了第一個(gè)Alarm。第一個(gè)Alarm顯式地設(shè)置了在特定的時(shí)間喚醒設(shè)備并發(fā)送Intent。第二個(gè)設(shè)置為從設(shè)備啟動(dòng)后,流逝時(shí)間為30分鐘,到達(dá)時(shí)間后如果設(shè)備在睡眠狀態(tài)也不會(huì)喚醒它。
- AlarmManager alarms = (AlarmManager)getSystemService(Context.ALARM_SERVICE);
String MY_RTC_ALARM = “MY_RTC_ALARM”;
String ALARM_ACTION = “MY_ELAPSED_ALARM”;
PendingIntent rtcIntent = PendingIntent.getBroadcast(this, 0, new Intent(MY_RTC_ALARM), 1);
PendingIntent elapsedIntent = PendingIntent.getBroadcast(this, 0, new Intent(ALARM_ACTION), 1);
Date t = new Date();
t.setTime(java.lang.System.currentTimeMillis() + 60*1000*5);
alarms.set(AlarmManager.RTC_WAKEUP, t.getTime(), rtcIntent);
alarms.set(AlarmManager.ELAPSED_REALTIME, 30*60*1000, elapsedIntent);
alarms.cancel(rtcIntent);
復(fù)制代碼 </div |
上一篇: Android 基本界面-文本編輯控件下一篇: 實(shí)戰(zhàn)Service BroadcastReceiver與AlarmManager
|