AlarmManager的学习与实现
综述
这个类提供了一种使用系统提供的alarm服务。这个服务允许用户安排他们的应用程序在将来的某一个时间点运行。当设置的alarm响起,那么之前系统为这个alarm注册的Intent就会自动的运行目标应用程序(如果此时应用程序还没有运行)。即使在系统处于休眠状态时(如果在此期间alarm响起,那么就会唤醒设备),系统注册的alarm依旧保持,但是当alarm被关闭或者是系统重启后,之前设置的alarm就会被清除。
在alarm的接收者的onReceive()方法执行的过程中,Alarm Manager就会持有一个CPU的锁(wake lock),这样就能够确保在处理alarm broadcast的操作执行完成之前系统不会进入休眠状态。一旦onReceive()方法执行完毕后,Alarm Manager就会释放持有的锁。这意味着,在某些情况下,一旦你的onReceive(0方法执行完成后,系统有可能立即进入休眠状态。如果你的alarm的接收者调用Context.startService()方法启动一个服务,那么系统还是有可能在启动这项服务之前就进入休眠状态。为了防址这种情况发生,你的BroadcastReceiver和Service需要实现一个独立的wake lock策略来确保系统在完成启动这项服务之前一直处于运行状态。
注意:Alarm Manager的意图是实现安排你的应用程序在某个特定的时刻运行,即使你的应用此刻并没有运行。对于一般的时间操作(例如:ticks、timeouts等等),使用Handler将会更加的简单和高效。
你不应该直接实例化这个类,取而代之的是通过如下方式获取:
这个类提供了一种使用系统提供的alarm服务。这个服务允许用户安排他们的应用程序在将来的某一个时间点运行。当设置的alarm响起,那么之前系统为这个alarm注册的Intent就会自动的运行目标应用程序(如果此时应用程序还没有运行)。即使在系统处于休眠状态时(如果在此期间alarm响起,那么就会唤醒设备),系统注册的alarm依旧保持,但是当alarm被关闭或者是系统重启后,之前设置的alarm就会被清除。
在alarm的接收者的onReceive()方法执行的过程中,Alarm Manager就会持有一个CPU的锁(wake lock),这样就能够确保在处理alarm broadcast的操作执行完成之前系统不会进入休眠状态。一旦onReceive()方法执行完毕后,Alarm Manager就会释放持有的锁。这意味着,在某些情况下,一旦你的onReceive(0方法执行完成后,系统有可能立即进入休眠状态。如果你的alarm的接收者调用Context.startService()方法启动一个服务,那么系统还是有可能在启动这项服务之前就进入休眠状态。为了防址这种情况发生,你的BroadcastReceiver和Service需要实现一个独立的wake lock策略来确保系统在完成启动这项服务之前一直处于运行状态。
注意:Alarm Manager的意图是实现安排你的应用程序在某个特定的时刻运行,即使你的应用此刻并没有运行。对于一般的时间操作(例如:ticks、timeouts等等),使用Handler将会更加的简单和高效。
你不应该直接实例化这个类,取而代之的是通过如下方式获取:
Context.getSystemService(Context.ALARM_SERVICE)
常用的方法如下:
set()方法是设置在某个时间执行,有三个参数:第一个是alarm的类型,主要有以下几种类型:
ELAPSED_REALTIME, ELAPSED_REALTIME_WAKEUP, RTC or RTC_WAKEUP,这个大家看文档就知道了。
第二个参数是:第二个是alarm触发的时间,这个值的设置和前面一个参数,也就是alarm的类型是有关的。
第三个参数是一个PendingIntent的对象,alarm一般是通过发出一个广播来实现的,所以应该定义一个PendingIntent来发出广播。
包含的常量如下图:
接下里我们就实现一个例子,通过一个按钮设置alarm,然后在设定的时间到后,就实现alarm的效果---显示一个toast,当然也可以通过一个按钮取消设置的闹钟。
第一步:新建一个工程,命名为alarmManager;
第二步:修改布局文件添加两个按钮,文件内容如下:
<?xml version="1.0" encoding="utf-8"?> <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android" android:layout_width="fill_parent" android:layout_height="fill_parent" android:orientation="vertical" > <TextView android:layout_width="fill_parent" android:layout_height="wrap_content" android:text="@string/hello" /> <Button android:id="@+id/set" android:layout_width="fill_parent" android:layout_height="wrap_content" android:text="@string/set"/> <Button android:id="@+id/cancel" android:layout_width="fill_parent" android:layout_height="wrap_content" android:text="@string/cancel"/> </LinearLayout>第四步:修改alarmManager.java文件,主要实现给两个按钮设置事件监听器,在其中主要实现alarm的广播的功能,当然还需要设置广播接收器,代码如下:
public class AlarmManagerActivity extends Activity { private Button setBtn, cancelBtn; /** Called when the activity is first created. */ @Override public void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.main); setBtn = (Button)findViewById(R.id.set); cancelBtn = (Button)findViewById(R.id.cancel); final AlarmManager am = (AlarmManager)this.getSystemService(ALARM_SERVICE); Intent intent = new Intent(); intent.setAction("com.maker.alarmManager.app.MY_ACTION"); intent.putExtra("msg", "闹钟事件发生了"); final PendingIntent pi = PendingIntent.getBroadcast(this, 0, intent, 0); final long time = System.currentTimeMillis(); setBtn.setOnClickListener(new View.OnClickListener() { @Override public void onClick(View v) { // TODO Auto-generated method stub am.setRepeating(AlarmManager.RTC_WAKEUP, time, 10*1000, pi); } }); cancelBtn.setOnClickListener(new View.OnClickListener() { @Override public void onClick(View v) { // TODO Auto-generated method stub am.cancel(pi); } }); } }第五步:实现广播接收器,在这的代码就是闹钟事件发生后要实现的功能:显示一条toast,代码如下:
public class MyReceiver extends BroadcastReceiver { @Override public void onReceive(Context context, Intent intent) { String msg = intent.getStringExtra("msg"); Toast.makeText(context, msg, Toast.LENGTH_LONG).show(); } }注意:实现了广播接收器MyReceiver,还要再工程的AndroidManifest文件中进行声明。
第六步:运行程序,如下图。