欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Android鬧鈴服務(wù)AlarmManager用法深入分析

 更新時(shí)間:2016年08月15日 09:07:51   作者:loving863  
這篇文章主要介紹了Android鬧鈴服務(wù)AlarmManager用法,結(jié)合實(shí)例形式深入分析了鬧鈴服務(wù)AlarmManager的功能、原理、定義與使用方法,需要的朋友可以參考下

本文實(shí)例講述了Android鬧鈴服務(wù)AlarmManager用法。分享給大家供大家參考,具體如下:

對(duì)應(yīng)AlarmManage有一個(gè)AlarmManagerServie服務(wù)程 序,該服務(wù)程序才是正真提供鬧鈴服務(wù)的,它主要維護(hù)應(yīng)用程序注冊(cè)下來的各類鬧鈴并適時(shí)的設(shè)置即將觸發(fā)的鬧鈴給鬧鈴設(shè)備(在系統(tǒng)中,linux實(shí)現(xiàn)的設(shè)備名 為"/dev/alarm"),并且一直監(jiān)聽鬧鈴設(shè)備,一旦有鬧鈴觸發(fā)或者是鬧鈴事件發(fā)生,AlarmManagerServie服務(wù)程序就會(huì)遍歷鬧鈴列 表找到相應(yīng)的注冊(cè)鬧鈴并發(fā)出廣播。該服務(wù)程序在系統(tǒng)啟動(dòng)時(shí)被系統(tǒng)服務(wù)程序system_service啟動(dòng)并初始化鬧鈴設(shè)備(/dev/alarm)。當(dāng) 然,在JAVA層的AlarmManagerService與Linux Alarm驅(qū)動(dòng)程序接口之間還有一層封裝,那就是JNI。

AlarmManager將應(yīng)用與服務(wù)分割開來后,使得應(yīng)用程序開發(fā)者不用 關(guān)心具體的服務(wù),而是直接通過AlarmManager來使用這種服務(wù)。這也許就是客戶/服務(wù)模式的好處吧。AlarmManager與 AlarmManagerServie之間是通過Binder來通信的,他們之間是多對(duì)一的關(guān)系。

在android系統(tǒng)中,AlarmManage提供了3個(gè)接口5種類型的鬧鈴服務(wù)。

3個(gè)接口:

// 取消已經(jīng)注冊(cè)的與參數(shù)匹配的鬧鈴
void cancel(PendingIntent operation)
//注冊(cè)一個(gè)新的鬧鈴
void set( int type, long triggerAtTime, PendingIntent operation)
//注冊(cè)一個(gè)重復(fù)類型的鬧鈴
void setRepeating( int type, long triggerAtTime, long interval, PendingIntent operation)
//設(shè)置時(shí)區(qū)
void setTimeZone(String timeZone)

Java代碼:

// 取消已經(jīng)注冊(cè)的與參數(shù)匹配的鬧鈴
void cancel(PendingIntent operation)
 //注冊(cè)一個(gè)新的鬧鈴
void set(int type, long triggerAtTime, PendingIntent operation)
 //注冊(cè)一個(gè)重復(fù)類型的鬧鈴
void setRepeating(int type, long triggerAtTime, long interval, PendingIntent operation)
 //設(shè)置時(shí)區(qū)
void setTimeZone(String timeZone)

5個(gè)鬧鈴類型

public static final int ELAPSED_REALTIME
// 當(dāng)系統(tǒng)進(jìn)入睡眠狀態(tài)時(shí),這種類型的鬧鈴不會(huì)喚醒系統(tǒng)。直到系統(tǒng)下次被喚醒才傳遞它,該鬧鈴所用的時(shí)間是相對(duì)時(shí)間,是從系統(tǒng)啟動(dòng)后開始計(jì)時(shí)的,包括睡眠時(shí) 間,可以通過調(diào)用SystemClock.elapsedRealtime()獲得。系統(tǒng)值是3 (0x00000003)。
public static final int ELAPSED_REALTIME_WAKEUP
//能喚醒系統(tǒng),用法同ELAPSED_REALTIME,系統(tǒng)值是2 (0x00000002) 。
public static final int RTC
//當(dāng)系統(tǒng)進(jìn)入睡眠狀態(tài)時(shí),這種類型的鬧鈴不會(huì)喚醒系統(tǒng)。直到系統(tǒng)下次被喚醒才傳遞它,該鬧鈴所用的時(shí)間是絕對(duì)時(shí)間,所用時(shí)間是UTC時(shí)間,可以通過調(diào)用 System.currentTimeMillis()獲得。系統(tǒng)值是1 (0x00000001) 。
public static final int RTC_WAKEUP
//能喚醒系統(tǒng),用法同RTC類型,系統(tǒng)值為 0 (0x00000000) 。
Public static final int POWER_OFF_WAKEUP
//能喚醒系統(tǒng),它是一種關(guān)機(jī)鬧鈴,就是說設(shè)備在關(guān)機(jī)狀態(tài)下也可以喚醒系統(tǒng),所以我們把它稱之為關(guān)機(jī)鬧鈴。使用方法同RTC類型,系統(tǒng)值為4(0x00000004)。

Java代碼 :

public static final int ELAPSED_REALTIME
//當(dāng)系統(tǒng)進(jìn)入睡眠狀態(tài)時(shí),這種類型的鬧鈴不會(huì)喚醒系統(tǒng)。直到系統(tǒng)下次被喚醒才傳遞它,該鬧鈴所用的時(shí)間是相對(duì)時(shí)間,是從系統(tǒng)啟動(dòng)后開始計(jì)時(shí)的,包括睡眠
時(shí)間,可以通過調(diào)用SystemClock.elapsedRealtime()獲得。系統(tǒng)值是3 (0x00000003)。
public static final int ELAPSED_REALTIME_WAKEUP
//能喚醒系統(tǒng),用法同ELAPSED_REALTIME,系統(tǒng)值是2 (0x00000002) 。
public static final int RTC
//當(dāng)系統(tǒng)進(jìn)入睡眠狀態(tài)時(shí),這種類型的鬧鈴不會(huì)喚醒系統(tǒng)。直到系統(tǒng)下次被喚醒才傳遞它,該鬧鈴所用的時(shí)間是絕對(duì)時(shí)間,所用時(shí)間是UTC時(shí)間,可以通過調(diào)用
 System.currentTimeMillis()獲得。系統(tǒng)值是1 (0x00000001) 。
public static final int RTC_WAKEUP
//能喚醒系統(tǒng),用法同RTC類型,系統(tǒng)值為 0 (0x00000000) 。
Public static final int POWER_OFF_WAKEUP
//能喚醒系統(tǒng),它是一種關(guān)機(jī)鬧鈴,就是說設(shè)備在關(guān)機(jī)狀態(tài)下也可以喚醒系統(tǒng),所以我們把它稱之為關(guān)機(jī)鬧鈴。使用方法同RTC類型,系統(tǒng)值為
4(0x00000004)。

注意一個(gè)重要的參數(shù)PendingIntent。這個(gè)PendingIntent可以說是 Intent的進(jìn)一步封裝,他既包含了Intent的描述又是Intent行為的執(zhí)行(這種定義也許不太嚴(yán)格),如果將Intent比作成一個(gè)訂單的 話,PendingIntent更像是一個(gè)下訂單的人,因?yàn)樗纫?fù)責(zé)將訂單發(fā)出去,也要負(fù)責(zé)訂單發(fā)送后的處理,比如發(fā)送成功后要準(zhǔn)備驗(yàn)收訂單貨物,發(fā)送 失敗后要重發(fā)還是取消訂單等操作。開發(fā)者可以通過調(diào)用
getActivity(Context, int, Intent, int)
getBroadcast(Context, int, Intent, int)
getService(Context, int, Intent, int)

三種不同方式來得到一個(gè)PendingIntent實(shí)例。

getBroadcast——通過該函數(shù)獲得的PendingIntent將會(huì) 扮演一個(gè)廣播的功能,就像調(diào)用 Context.sendBroadcast()函數(shù)一樣。當(dāng)系統(tǒng)通過它要發(fā)送一個(gè)intent時(shí)要采用廣播的形式,并且在該intent中會(huì)包含相應(yīng)的 intent接收對(duì)象,當(dāng)然這個(gè)對(duì)象我們可以在創(chuàng)建PendingIntent的時(shí)候指定,也可以通過ACTION 和CATEGORY等描述讓系統(tǒng)自動(dòng)找到該行為處理對(duì)象。

Intent intent = new Intent(AlarmController. this , OneShotAlarm. class );
PendingIntent sender = PendingIntent.getBroadcast(AlarmController.this , 0 , intent, 0 );

Java代碼:

Intent intent = new Intent(AlarmController.this, OneShotAlarm.class);
PendingIntent sender = PendingIntent.getBroadcast(AlarmController.this, 0, intent, 0);

getActivity——通過該函數(shù)獲得的PendingIntent可以直 接啟動(dòng)新的activity, 就像調(diào)用 Context.startActivity(Intent)一樣.不過值得注意的是要想這個(gè)新的Activity不再是當(dāng)前進(jìn)程存在的Activity 時(shí)。我們?cè)趇ntent中必須使用Intent.FLAG_ACTIVITY_NEW_TASK.

// The PendingIntent to launch our activity if the user selects this notification
PendingIntent contentIntent = PendingIntent.getActivity(this , 0 , new Intent( this , AlarmService. class ), 0 );

Java代碼:

// The PendingIntent to launch our activity if the user selects this notification
PendingIntent contentIntent = PendingIntent.getActivity(this, 0, new Intent(this, AlarmService.class), 0);

getService——通過該函數(shù)獲得的PengdingIntent可以直接啟動(dòng)新的Service,就像調(diào)用Context.startService()一樣。

// Create an IntentSender that will launch our service, to be scheduled
// with the alarm manager.
mAlarmSender = PendingIntent.getService(AlarmService.this ,
 0 , new Intent(AlarmService. this , AlarmService_Service. class ), 0 );

更多關(guān)于Android相關(guān)內(nèi)容感興趣的讀者可查看本站專題:《Android開發(fā)入門與進(jìn)階教程》、《Android調(diào)試技巧與常見問題解決方法匯總》、《Android多媒體操作技巧匯總(音頻,視頻,錄音等)》、《Android基本組件用法總結(jié)》、《Android視圖View技巧總結(jié)》、《Android布局layout技巧總結(jié)》及《Android控件用法總結(jié)

希望本文所述對(duì)大家Android程序設(shè)計(jì)有所幫助。

相關(guān)文章

  • Android實(shí)現(xiàn)短視頻畫心效果

    Android實(shí)現(xiàn)短視頻畫心效果

    這篇文章主要為大家詳細(xì)介紹了Android實(shí)現(xiàn)短視頻畫心效果,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2021-05-05
  • Android中Intent與Bundle的使用詳解

    Android中Intent與Bundle的使用詳解

    這篇文章主要給大家總結(jié)介紹了關(guān)于Android中傳值Intent與Bundle的關(guān)系,文中通過示例代碼以及圖文介紹的非常詳細(xì),對(duì)各位Android開發(fā)者們具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面來一起學(xué)習(xí)學(xué)習(xí)吧<BR>
    2022-11-11
  • Android仿人人客戶端滑動(dòng)菜單的側(cè)滑菜單效果

    Android仿人人客戶端滑動(dòng)菜單的側(cè)滑菜單效果

    這篇文章主要介紹了Android仿人人客戶端滑動(dòng)菜單的側(cè)滑特效實(shí)現(xiàn)代碼,小編覺得挺不錯(cuò)的,分享給大家供大家參考
    2018-05-05
  • android生命周期深入分析(一)

    android生命周期深入分析(一)

    Android 程序的生命周期是由系統(tǒng)控制而非程序自身直接控制,本文將詳細(xì)介紹,需要的朋友可以參考下
    2012-12-12
  • Flutter實(shí)現(xiàn)抖音點(diǎn)贊效果

    Flutter實(shí)現(xiàn)抖音點(diǎn)贊效果

    抖音的點(diǎn)贊效果在第一次看到的時(shí)候,總有一種眼前一亮的感覺。一邊看視頻,還能在視頻上點(diǎn)贊,而且整個(gè)屏幕都能夠點(diǎn)贊,并伴隨動(dòng)畫,還是很炫酷的。今天我們用Flutter來實(shí)現(xiàn)一下這個(gè)效果
    2021-05-05
  • Android中Service實(shí)時(shí)向Activity傳遞數(shù)據(jù)實(shí)例分析

    Android中Service實(shí)時(shí)向Activity傳遞數(shù)據(jù)實(shí)例分析

    這篇文章主要介紹了Android中Service實(shí)時(shí)向Activity傳遞數(shù)據(jù)的方法,實(shí)例分析了Service組件基于線程操作實(shí)現(xiàn)數(shù)值實(shí)時(shí)傳遞的相關(guān)技巧,需要的朋友可以參考下
    2015-09-09
  • Android實(shí)現(xiàn)簡(jiǎn)單計(jì)算器

    Android實(shí)現(xiàn)簡(jiǎn)單計(jì)算器

    這篇文章主要為大家詳細(xì)介紹了Android實(shí)現(xiàn)簡(jiǎn)單計(jì)算器,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2021-10-10
  • Android筆記之:在ScrollView中嵌套ListView的方法

    Android筆記之:在ScrollView中嵌套ListView的方法

    本篇文章是對(duì)Android中在ScrollView中嵌套ListView的方法進(jìn)行了詳細(xì)的分析介紹,需要的朋友參考下
    2013-05-05
  • Android百度地圖添加Marker失真問題的解決方案

    Android百度地圖添加Marker失真問題的解決方案

    本篇文章主要介紹了Android百度地圖添加Marker失真問題的解決方案,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧
    2018-01-01
  • Android實(shí)現(xiàn)登錄注冊(cè)頁(yè)面(下)

    Android實(shí)現(xiàn)登錄注冊(cè)頁(yè)面(下)

    這篇文章主要介紹了Android實(shí)現(xiàn)登錄注冊(cè)頁(yè)面的第二篇,實(shí)現(xiàn)驗(yàn)證登錄和記住密碼功能,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2022-04-04

最新評(píng)論