Chinaunix首页 | 论坛 | 博客
  • 博客访问: 1071513
  • 博文数量: 403
  • 博客积分: 10272
  • 博客等级: 上将
  • 技术积分: 4407
  • 用 户 组: 普通用户
  • 注册时间: 2012-02-24 14:22
文章分类

全部博文(403)

文章存档

2012年(403)

分类: 嵌入式

2012-03-16 15:26:19

AlarmManager 包含的主要方法:

  1. // 取消已经注册的与参数匹配的定时器
  2. void cancel(PendingIntent operation)
  3. //注册一个新的延迟定时器
  4. void set(int type, long triggerAtTime, PendingIntent operation)
  5. //注册一个重复类型的定时器
  6. void setRepeating(int type, long triggerAtTime, long interval, PendingIntent operation)
  7. //注册一个非精密的重复类型定时器
  8. void setInexactRepeating (int type, long triggerAtTime, long interval, PendingIntent operation)
  9. //设置时区
  10. void setTimeZone(String timeZone)


定时器主要类型:

  1. public static final int ELAPSED_REALTIME
  2. // 当系统进入睡眠状态时,这种类型的闹铃不会唤醒系统。直到系统下次被唤醒才传递它,该闹铃所用的时间是相对时间,是从系统启动后开始计时的,包括睡眠时 间,可以通过调用SystemClock.elapsedRealtime()获得。系统值是3 (0x00000003)。
  3. public static final int ELAPSED_REALTIME_WAKEUP
  4. //能唤醒系统,用法同ELAPSED_REALTIME,系统值是2 (0x00000002) 。
  5. public static final int RTC
  6. //当系统进入睡眠状态时,这种类型的闹铃不会唤醒系统。直到系统下次被唤醒才传递它,该闹铃所用的时间是绝对时间,所用时间是UTC时间,可以通过调用 System.currentTimeMillis()获得。系统值是1 (0x00000001) 。
  7. public static final int RTC_WAKEUP
  8. //能唤醒系统,用法同RTC类型,系统值为 0 (0x00000000) 。
  9. Public static final int POWER_OFF_WAKEUP
  10. //能唤醒系统,它是一种关机闹铃,就是说设备在关机状态下也可以唤醒系统,所以我们把它称之为关机闹铃。使用方法同RTC类型,系统值为4(0x00000004)。

当你的应用不在运行,而此时你仍然需要你的应用去执行一些操作(比如,短信拦截),只有这种时候才使用AlarmManager, 其他正常情况下的,推荐使用Handler。

AlarmManager 生命周期:

repeating AlarmManager一旦启动就会一直在后台运行(除非执行cancel方法),可以在“应用管理”中看到这个应用状态是正在运行。 “强行停止”可以让Alarmmanager停掉。

尝试了几种任务管理器, 都只能重置计数器(确实释放内存了),但都无法关闭定时器,只有系统自带的“强行停止”奏效。

如果某个AlarmManager已经启动, 程序又再次去启动它,只要PendingIntent是一样,那么之前那个AlarmManager会被release掉。

如何使用AlarmManager?

使用AlarmManager共有三种方式, 都是通过PendingIntent。

  1. getActivity(Context, int, Intent, int)
  2. getBroadcast(Context, int, Intent, int)
  3. getService(Context, int, Intent, int)

这边就举一个使用BroadCast的例子。

首先是创建一个BroadCast类,需要继承BroadCastReceiver, 如下:

  1. /*
  2. * Copyright (c) 2011, Yulong Information Technologies
  3. * All rights reserved.
  4. *
  5. * @Project: AlarmTest
  6. * @author: Robot
  7. */
  8. package com.yfz;
  9. import android.content.BroadcastReceiver;
  10. import android.content.Context;
  11. import android.content.Intent;
  12. import android.util.Log;
  13. /**
  14. * @author Robot
  15. * @weibo
  16. * @date Nov 18, 2011
  17. */
  18. public class ActionBroadCast extends BroadcastReceiver {
  19. private static int num = 0;
  20. /* (non-Javadoc)
  21. * @see android.content.BroadcastReceiver#onReceive(android.content.Context, android.content.Intent)
  22. */
  23. @Override
  24. public void onReceive(Context context, Intent intent) {
  25. // TODO Auto-generated method stub
  26. Log.e("ActionBroadCast", "New Message !" + num++);
  27. }
  28. }

下面就让我们启动AlarmManager, 这边就直接在Activity中启动了, 如下:

  1. package com.yfz;
  2. import android.app.Activity;
  3. import android.app.AlarmManager;
  4. import android.app.PendingIntent;
  5. import android.content.Intent;
  6. import android.os.Bundle;
  7. public class AlarmTestActivity extends Activity {
  8. /** Called when the activity is first created. */
  9. @Override
  10. public void onCreate(Bundle savedInstanceState) {
  11. super.onCreate(savedInstanceState);
  12. setContentView(R.layout.main);
  13. AlarmManager am = (AlarmManager)getSystemService(ALARM_SERVICE);
  14. PendingIntent pi = PendingIntent.getBroadcast(this, 0, new Intent(this, ActionBroadCast.class), Intent.FLAG_ACTIVITY_NEW_TASK);
  15. long now = System.currentTimeMillis();
  16. am.setInexactRepeating(AlarmManager.RTC_WAKEUP, now, 3000, pi);
  17. }
  18. }

这边用Repeating的方式。 每隔3秒发一条广播消息过去。RTC_WAKEUP的方式,保证即使手机休眠了,也依然会发广播消息。

最后看一下AndroidManifest文件,主要是注册一下Activity和BroadCast。 (实际使用中最好再加个filter,自己定义一个Action比较好)

  1. xml version="1.0" encoding="utf-8"?>
  2. <manifest xmlns:android=""
  3. package="com.yfz"
  4. android:versionCode="1"
  5. android:versionName="1.0" >
  6. <uses-sdk android:minSdkVersion="7" />
  7. <application
  8. android:icon="@drawable/ic_launcher"
  9. android:label="@string/app_name" >
  10. <activity
  11. android:label="@string/app_name"
  12. android:name=".AlarmTestActivity" >
  13. <intent-filter >
  14. <action android:name="android.intent.action.MAIN" />
  15. <category android:name="android.intent.category.LAUNCHER" />
  16. intent-filter>
  17. activity>
  18. <receiver
  19. android:name="ActionBroadCast">
  20. receiver>
  21. application>
  22. manifest>

Service的其实也差不多,只要在OnStart()方法中写需要执行的操作即可。

做了一个例子,包含了使用AlarmManager的所有三种方式。已经上传至CSDN,下载地址:

阅读(376) | 评论(0) | 转发(0) |
给主人留下些什么吧!~~