1.獲得AlarmManager實(shí)例對(duì)象
AlarmManager alarmManager = (AlarmManager) getSystemService(Service.ALARM_SERVICE);
2.相關(guān)方法以及詳解
2.1.
方法:set(int type,long startTime,PendingIntent pi)
作用:一次性鬧鐘。
2.2.
方法:setRepeating(int type,long startTime,long intervalTime,PendingIntent pi)
作用:重復(fù)性鬧鐘,和3有區(qū)別,3鬧鐘間隔時(shí)間不固定。
2.3.
方法:setInexactRepeating(int type,long startTime,long intervalTime,PendingIntent pi)
作用:重復(fù)性鬧鐘,時(shí)間不固定。
2.4.
方法:cancel(PendingIntent pi)
作用:取消AlarmManager的定時(shí)服務(wù)。
2.5.
方法:getNextAlarmClock()
作用:得到下一個(gè)鬧鐘,返回值A(chǔ)larmManager.AlarmClockInfo。
2.6.
方法:setAndAllowWhileIdle(int type, long triggerAtMillis, PendingIntent operation)?
作用:和set方法類似,這個(gè)鬧鐘運(yùn)行在系統(tǒng)處于低電模式時(shí)有效。
2.7.
方法:setExact(int type, long triggerAtMillis, PendingIntent operation)
作用:在規(guī)定的時(shí)間精確的執(zhí)行鬧鐘,比set方法設(shè)置的精度更高。
2.8.
方法:setTime(long millis)
作用:設(shè)置系統(tǒng)墻上的時(shí)間。
2.9.
方法:setTimeZone(String timeZone)
作用:設(shè)置系統(tǒng)持續(xù)的默認(rèn)時(shí)區(qū)。
2.10.
方法:setWindow(int type, long windowStartMillis, long windowLengthMillis, PendingIntent p)
作用:設(shè)置一個(gè)鬧鐘在給定的時(shí)間窗觸發(fā)。類似于set,該方法允許應(yīng)用程序精確地控制操作系統(tǒng)調(diào)?
整鬧鐘觸發(fā)時(shí)間的程度。
2.11.
2.11.1.Type(鬧鐘類型)
有五個(gè)可選值:?
AlarmManager.ELAPSED_REALTIME:?
鬧鐘在手機(jī)睡眠狀態(tài)下不可用,該狀態(tài)下鬧鐘使用相對(duì)時(shí)間(相對(duì)于系統(tǒng)啟動(dòng)開始),狀態(tài)值為3;?
AlarmManager.ELAPSED_REALTIME_WAKEUP?
鬧鐘在睡眠狀態(tài)下會(huì)喚醒系統(tǒng)并執(zhí)行提示功能,該狀態(tài)下鬧鐘也使用相對(duì)時(shí)間,狀態(tài)值為2;?
AlarmManager.RTC?
鬧鐘在睡眠狀態(tài)下不可用,該狀態(tài)下鬧鐘使用絕對(duì)時(shí)間,即當(dāng)前系統(tǒng)時(shí)間,狀態(tài)值為1;?
AlarmManager.RTC_WAKEUP?
表示鬧鐘在睡眠狀態(tài)下會(huì)喚醒系統(tǒng)并執(zhí)行提示功能,該狀態(tài)下鬧鐘使用絕對(duì)時(shí)間,狀態(tài)值為0;?
AlarmManager.POWER_OFF_WAKEUP?
表示鬧鐘在手機(jī)關(guān)機(jī)狀態(tài)下也能正常進(jìn)行提示功能,所以是5個(gè)狀態(tài)中用的最多的狀態(tài)之一,該狀態(tài)下鬧鐘也是用絕對(duì)時(shí)間,狀態(tài)值為4;不過本狀態(tài)好像受SDK版本影響,某些版本并不支持;
2.11.2.startTime
鬧鐘的第一次執(zhí)行時(shí)間,以毫秒為單位,可以自定義時(shí)間,不過一般使用當(dāng)前時(shí)間。?需要注意的是,本屬性與第一個(gè)屬性(type)密切相關(guān),如果第一個(gè)參數(shù)對(duì)應(yīng)的鬧鐘使用的是相對(duì)時(shí)間?(ELAPSED_REALTIME和ELAPSED_REALTIME_WAKEUP),那么本屬性就得使用相對(duì)時(shí)間?(相對(duì)于系統(tǒng)啟動(dòng)時(shí)間來說),比如當(dāng)前時(shí)間就表示為:SystemClock.elapsedRealtime();?如果第一個(gè)參數(shù)對(duì)應(yīng)的鬧鐘使用的是絕對(duì)時(shí)間(RTC、RTC_WAKEUP、POWER_OFF_WAKEUP),?那么本屬性就得使用絕對(duì)時(shí)間,比如當(dāng)前時(shí)間就表示 為:System.currentTimeMillis()。
2.11.3.intervalTime
表示兩次鬧鐘執(zhí)行的間隔時(shí)間,也是以毫秒為單位。
2.11.4.PendingIntent
綁定了鬧鐘的執(zhí)行動(dòng)作,比如發(fā)送一個(gè)廣播、給出提示等等。?PendingIntent是Intent的封裝類。需要注意的是,如果是通過啟動(dòng)服務(wù)來實(shí)現(xiàn)鬧鐘提 示的話,PendingIntent對(duì)象的獲取就應(yīng)該采用Pending.getService?(Context c,int i,Intent intent,int j)方法;如果是通過廣播來實(shí)現(xiàn)鬧鐘?提示的話,PendingIntent對(duì)象的獲取就應(yīng)該采用 PendingIntent.getBroadcast?(Context c,int i,Intent intent,int j)方法;如果是采用Activity的方式來實(shí)?現(xiàn)鬧鐘提示的話,PendingIntent對(duì)象的獲取就應(yīng)該采用?PendingIntent.getActivity(Context c,int i,Intent intent,int j)方法。?如果這三種方法錯(cuò)用了的話,雖然不會(huì)報(bào)錯(cuò),但是看不到鬧鐘提示效果。
附2:Timer類與AlarmManager類區(qū)別
Timer即定時(shí)器,一般寫定時(shí)任務(wù)的時(shí)候?肯定離不開他,但是在Android里,他卻有個(gè)短板,不太適合那些需要長(zhǎng)時(shí)間在后臺(tái)運(yùn)行的?定時(shí)任務(wù),因?yàn)锳ndroid設(shè)備有自己的休眠策略,當(dāng)長(zhǎng)時(shí)間的無操作,設(shè)備會(huì)自動(dòng)讓CPU進(jìn)入休眠狀態(tài),這樣就可能導(dǎo)致Timer中的定時(shí)任務(wù)無法正常運(yùn)行。而AlarmManager則不存在?這種情況,因?yàn)樗哂袉拘袰PU的功能,可以保證每次需要執(zhí)行特定任務(wù)時(shí)CPU都能正常工作,?或者說當(dāng)CPU處于休眠時(shí)注冊(cè)的鬧鐘會(huì)被保留(可以喚醒CPU),但如果設(shè)備被關(guān)閉,或者重新?啟動(dòng)的話,鬧鐘將被清除。