Chinaunix首页 | 论坛 | 博客
  • 博客访问: 430353
  • 博文数量: 113
  • 博客积分: 2228
  • 博客等级: 大尉
  • 技术积分: 1341
  • 用 户 组: 普通用户
  • 注册时间: 2012-10-24 15:07
文章分类

全部博文(113)

文章存档

2013年(52)

2012年(61)

我的朋友

分类: 嵌入式

2012-12-29 11:10:27


Android Alarm manager定时闹钟开发详解

Alarmmanager主要管理硬件时钟。 
一些与时间相关的应用,如日历,闹钟等需要使用AlarmManager的服务。Alarmmanager 
功能相对比较简单,相关代码位于 
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 
这部分代码直接管理硬件时钟,设备名为/dev/alarm。包括打开设备,关闭设备,设置时区, 
设置触发时间(timeout),以及等待时钟触发。 
二.frameworks/base/services/java/com/android/server/AlarmManagerService.java 
这部分封装目录一中的代码,向上提供java接口,同时与客户端(如calendar)交互,接 
收来自客户端的时钟设置请求,并在时钟触发时通知客户端。 
Alarm是在预定的时间上触发Intent的一种独立的方法。 
Alarm超出了应用程序的作用域,所以它们可以用于触发应用程序事件或动作,甚至在应用 
程序关闭之后。与BroadcastReceiver结合,它们可以变得尤其的强大,可以通过设置Alarm 
来启动应用程序或者执行动作,而应用程序不需要打开或者处于活跃状态。 
举个例子,你可以使用Alarm来实现一个闹钟程序,执行正常的网络查询,或者在“非高峰” 
时间安排耗时或有代价的操作。 
对于仅在应用程序生命周期内发生的定时操作,Handler类与Timer和Thread类的结合是 
一个更好的选择,它允许Android更好地控制系统资源。 
Android中的Alarm在设备处于睡眠模式时仍保持活跃,它可以设置来唤醒设备;然而,所 
有的Alarm在设备重启时都会被取消。 
Alarm的操作通过AlarmManager来处理,通过getSystemService可以获得其系统服务,如 

下所示: 
AlarmManageralarms=(AlarmManager)getSystemService(Context.ALARM_SERVICE); 
为了创建一个新的Alarm,使用set方法并指定一个Alarm类型、触发时间和在Alarm触发 
时要调用的Intent。如果你设定的Alarm发生在过去,那么,它将立即触发。 
这里有4种Alarm类型。你的选择将决定你在set方法中传递的时间值代表什么,是特定的 
时间或者是时间流逝: 
 RTC_WAKEUP 
在指定的时刻(设置Alarm的时候),唤醒设备来触发Intent。 
 RTC 
在一个显式的时间触发Intent,但不唤醒设备。 
 ELAPSED_REALTIME 
从设备启动后,如果流逝的时间达到总时间,那么触发Intent,但不唤醒设备。流逝的时 
间包括设备睡眠的任何时间。注意一点的是,时间流逝的计算点是自从它最后一次启动算起。 
 ELAPSED_REALTIME_WAKEUP 
从设备启动后,达到流逝的总时间后,如果需要将唤醒设备并触发Intent。 
Alarm的创建过程演示如下片段所示: 

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将被触发。设置另外一个Alarm并使用相同的 
PendingIntent来替代之前存在的Alarm。 
取消一个Alarm,调用AlarmManager的cancel方法,传入你不再希望被触发的 
PendingIntent,如下面的代码所示: 
alarms.cancel(pendingIntent); 
接下来的代码片段中,设置了两个Alarm,随后马上取消了第一个Alarm。第一个Alarm显 
式地设置了在特定的时间唤醒设备并发送Intent。第二个设置为从设备启动后,流逝时间 
为30分钟,到达时间后如果设备在睡眠状态也不会唤醒它。 
AlarmManageralarms=(AlarmManager)getSystemService(Context.ALARM_SERVICE); 
StringMY_RTC_ALARM=“MY_RTC_ALARM”; 
StringALARM_ACTION=“MY_ELAPSED_ALARM”; 
PendingIntentrtcIntent=PendingIntent.getBroadcast(this,0,new 
Intent(MY_RTC_ALARM),1); 

PendingIntentelapsedIntent=PendingIntent.getBroadcast(this,0,new 
Intent(ALARM_ACTION),1); 
//Wakeupandfireintentin5hours.(注释可能有错) 
Datet=newDate(); 
t.setTime(java.lang.System.currentTimeMillis()+60*1000*5); 
alarms.set(AlarmManager.RTC_WAKEUP,t.getTime(),rtcIntent); 
//Fireintentin30minsifalreadyawake. 
alarms.set(AlarmManager.ELAPSED_REALTIME,30*60*1000,elapsedIntent); 
//Cancelthefirstalarm. 
alarms.cancel(rtcIntent); 
Alarmmanager主要管理硬件时钟。 
一些与时间相关的应用,如日历,闹钟等需要使用AlarmManager的服务。Alarmmanager 
功能相对比较简单,相关代码位于 
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 
这部分代码直接管理硬件时钟,设备名为/dev/alarm。包括打开设备,关闭设备,设置时区, 
设置触发时间(timeout),以及等待时钟触发。 
二.frameworks/base/services/java/com/android/server/AlarmManagerService.java 
这部分封装目录一中的代码,向上提供java接口,同时与客户端(如calendar)交互,接 
收来自客户端的时钟设置请求,并在时钟触发时通知客户端。 
Alarm是在预定的时间上触发Intent的一种独立的方法。 
Alarm超出了应用程序的作用域,所以它们可以用于触发应用程序事件或动作,甚至在应用 
程序关闭之后。与BroadcastReceiver结合,它们可以变得尤其的强大,可以通过设置Alarm 
来启动应用程序或者执行动作,而应用程序不需要打开或者处于活跃状态。 

举个例子,你可以使用Alarm来实现一个闹钟程序,执行正常的网络查询,或者在“非高峰” 
时间安排耗时或有代价的操作。 
对于仅在应用程序生命周期内发生的定时操作,Handler类与Timer和Thread类的结合是 
一个更好的选择,它允许Android更好地控制系统资源。 
Android中的Alarm在设备处于睡眠模式时仍保持活跃,它可以设置来唤醒设备;然而,所 
有的Alarm在设备重启时都会被取消。 
Alarm的操作通过AlarmManager来处理,通过getSystemService可以获得其系统服务,如 
下所示: 
AlarmManageralarms=(AlarmManager)getSystemService(Context.ALARM_SERVICE); 
为了创建一个新的Alarm,使用set方法并指定一个Alarm类型、触发时间和在Alarm触发 
时要调用的Intent。如果你设定的Alarm发生在过去,那么,它将立即触发。 
这里有4种Alarm类型。你的选择将决定你在set方法中传递的时间值代表什么,是特定的 
时间或者是时间流逝: 
 RTC_WAKEUP 
在指定的时刻(设置Alarm的时候),唤醒设备来触发Intent。 
 RTC 
在一个显式的时间触发Intent,但不唤醒设备。 

 ELAPSED_REALTIME 
从设备启动后,如果流逝的时间达到总时间,那么触发Intent,但不唤醒设备。流逝的时 
间包括设备睡眠的任何时间。注意一点的是,时间流逝的计算点是自从它最后一次启动算起。 
 ELAPSED_REALTIME_WAKEUP 
从设备启动后,达到流逝的总时间后,如果需要将唤醒设备并触发Intent。 
Alarm的创建过程演示如下片段所示: 
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将被触发。设置另外一个Alarm并使用相同的 
PendingIntent来替代之前存在的Alarm。 
取消一个Alarm,调用AlarmManager的cancel方法,传入你不再希望被触发的 
PendingIntent,如下面的代码所示: 
alarms.cancel(pendingIntent); 

接下来的代码片段中,设置了两个Alarm,随后马上取消了第一个Alarm。第一个Alarm显 
式地设置了在特定的时间唤醒设备并发送Intent。第二个设置为从设备启动后,流逝时间 
为30分钟,到达时间后如果设备在睡眠状态也不会唤醒它。 
AlarmManageralarms=(AlarmManager)getSystemService(Context.ALARM_SERVICE); 
StringMY_RTC_ALARM=“MY_RTC_ALARM”; 
StringALARM_ACTION=“MY_ELAPSED_ALARM”; 
PendingIntentrtcIntent=PendingIntent.getBroadcast(this,0,new 
Intent(MY_RTC_ALARM),1); 
PendingIntentelapsedIntent=PendingIntent.getBroadcast(this,0,new 
Intent(ALARM_ACTION),1); 
//Wakeupandfireintentin5hours.(注释可能有错) 
Datet=newDate(); 
t.setTime(java.lang.System.currentTimeMillis()+60*1000*5); 
alarms.set(AlarmManager.RTC_WAKEUP,t.getTime(),rtcIntent); 
//Fireintentin30minsifalreadyawake. 
alarms.set(AlarmManager.ELAPSED_REALTIME,30*60*1000,elapsedIntent); 
//Cancelthefirstalarm. 
alarms.cancel(rtcIntent); 
阅读(7008) | 评论(0) | 转发(0) |
给主人留下些什么吧!~~