溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務(wù)條款》

Android中如何利用Alarmmanager實現(xiàn)一個定時鬧鐘

發(fā)布時間:2022-04-12 14:19:31 來源:億速云 閱讀:418 作者:iii 欄目:編程語言

這篇文章主要講解了“Android中如何利用Alarmmanager實現(xiàn)一個定時鬧鐘”,文中的講解內(nèi)容簡單清晰,易于學習與理解,下面請大家跟著小編的思路慢慢深入,一起來研究和學習“Android中如何利用Alarmmanager實現(xiàn)一個定時鬧鐘”吧!

Alarmmanager主要管理硬件時鐘。一些與時間相關(guān)的應(yīng)用,如日歷,鬧鐘等需要使用AlarmManager的服務(wù)。Alarmmanager功能相對比較簡單,相關(guān)代碼位于:

frameworks/base/core/jni/server/com_android_server_AlarmManagerService.cpp
frameworks/base/services/java/com/android/server/AlarmManagerService.java

一.frameworks/base/core/jni/server/com_android_server_AlarmManagerService.cpp

這部分代碼直接管理硬件時鐘,設(shè)備名為/dev/alarm。包括打開設(shè)備,關(guān)閉設(shè)備,設(shè)置時區(qū),設(shè)置觸發(fā)時間(timeout),以及等待時鐘觸發(fā)。

二.frameworks/base/services/java/com/android/server/AlarmManagerService.java

這部分封裝目錄一中的代碼,向上提供java接口,同時與客戶端(如calendar)交互,接收來自客戶端的時鐘設(shè)置請求,并在時鐘觸發(fā)時通知客戶端。

Alarm是在預(yù)定的時間上觸發(fā)Intent的一種獨立的方法。

Alarm超出了應(yīng)用程序的作用域,所以它們可以用于觸發(fā)應(yīng)用程序事件或動作,甚至在應(yīng)用程序關(guān)閉之后。與BroadcastReceiver結(jié)合,它們可以變得尤其的強大,可以通過設(shè)置Alarm來啟動應(yīng)用程序或者執(zhí)行動作,而應(yīng)用程序不需要打開或者處于活躍狀態(tài)。

舉個例子,你可以使用Alarm來實現(xiàn)一個鬧鐘程序,執(zhí)行正常的網(wǎng)絡(luò)查詢,或者在“非高峰”時間安排耗時或有代價的操作。

對于僅在應(yīng)用程序生命周期內(nèi)發(fā)生的定時操作,Handler類與Timer和Thread類的結(jié)合是一個更好的選擇,它允許Android更好地控制系統(tǒng)資源。

Android中的Alarm在設(shè)備處于睡眠模式時仍保持活躍,它可以設(shè)置來喚醒設(shè)備;然而,所有的Alarm在設(shè)備重啟時都會被取消。

Alarm的操作通過AlarmManager來處理,通過getSystemService可以獲得其系統(tǒng)服務(wù),如下所示:

AlarmManageralarms=(AlarmManager)getSystemService(Context.ALARM_SERVICE);

為了創(chuàng)建一個新的Alarm,使用set方法并指定一個Alarm類型、觸發(fā)時間和在Alarm觸發(fā)時要調(diào)用的Intent。如果你設(shè)定的Alarm發(fā)生在過去,那么,它將立即觸發(fā)。

這里有4種Alarm類型。你的選擇將決定你在set方法中傳遞的時間值代表什么,是特定的時間或者是時間流逝:

RTC_WAKEUP

在指定的時刻(設(shè)置Alarm的時候),喚醒設(shè)備來觸發(fā)Intent。

RTC

在一個顯式的時間觸發(fā)Intent,但不喚醒設(shè)備。

ELAPSED_REALTIME

從設(shè)備啟動后,如果流逝的時間達到總時間,那么觸發(fā)Intent,但不喚醒設(shè)備。流逝的時間包括設(shè)備睡眠的任何時間。注意一點的是,時間流逝的計算點是自從它***一次啟動算起。

ELAPSED_REALTIME_WAKEUP

從設(shè)備啟動后,達到流逝的總時間后,如果需要將喚醒設(shè)備并觸發(fā)Intent。

Alarm的創(chuàng)建過程演示如下片段所示:

intalarmType=AlarmManager.ELAPSED_REALTIME_WAKEUP; longtimeOrLengthofWait=10000; StringALARM_ACTION=“ALARM_ACTION”; IntentintentToFire=newIntent(ALARM_ACTION); PendingIntentpendingIntent=PendingIntent.getBroadcast(this,0,intentToFire, 0); alarms.set(alarmType,timeOrLengthofWait,pendingIntent);

當Alarm到達時,你指定的PendingIntent將被觸發(fā)。設(shè)置另外一個Alarm并使用相同的PendingIntent來替代之前存在的Alarm。

取消一個Alarm,調(diào)用AlarmManager的cancel方法,傳入你不再希望被觸發(fā)的  PendingIntent,如下面的代碼所示:

alarms.cancel(pendingIntent);

接下來的代碼片段中,設(shè)置了兩個Alarm,隨后馬上取消了***個Alarm。***個Alarm顯  式地設(shè)置了在特定的時間喚醒設(shè)備并發(fā)送Intent。第二個設(shè)置為從設(shè)備啟動后,流逝時間  為30分鐘,到達時間后如果設(shè)備在睡眠狀態(tài)也不會喚醒它。

  1. AlarmManageralarms=(AlarmManager)getSystemService(Context.ALARM_SERVICE); 

  2. StringMY_RTC_ALARM=“MY_RTC_ALARM”; 

  3. StringALARM_ACTION=“MY_ELAPSED_ALARM”; 

  4. PendingIntentrtcIntent=PendingIntent.getBroadcast(this,0,new Intent(MY_RTC_ALARM),1); 

  5. PendingIntentelapsedIntent=PendingIntent.getBroadcast(this,0,new Intent(ALARM_ACTION),1); 

  6. //Wakeupandfireintentin5hours.(注釋可能有錯) 

  7. Datet=newDate(); 

  8. t.setTime(java.lang.System.currentTimeMillis()+60*1000*5); 

  9. alarms.set(AlarmManager.RTC_WAKEUP,t.getTime(),rtcIntent); 

  10. //Fireintentin30minsifalreadyawake. 

  11. alarms.set(AlarmManager.ELAPSED_REALTIME,30*60*1000,elapsedIntent); 

  12. //Cancelthefirstalarm. 

  13. alarms.cancel(rtcIntent); 

感謝各位的閱讀,以上就是“Android中如何利用Alarmmanager實現(xiàn)一個定時鬧鐘”的內(nèi)容了,經(jīng)過本文的學習后,相信大家對Android中如何利用Alarmmanager實現(xiàn)一個定時鬧鐘這一問題有了更深刻的體會,具體使用情況還需要大家實踐驗證。這里是億速云,小編將為大家推送更多相關(guān)知識點的文章,歡迎關(guān)注!

向AI問一下細節(jié)

免責聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進行舉報,并提供相關(guān)證據(jù),一經(jīng)查實,將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI