展会信息港展会大全

Android之AlarmManager
来源:互联网   发布日期:2016-01-13 21:40:36   浏览:4205次  

导读:// 取消已经注册的与参数匹配的定时器void cancel(PendingIntent operation)//注册一个新的延迟定时器void set(int type, long triggerAtTime, PendingIntent operation)//注册一个重复类型的定时器voi......

// 取消已经注册的与参数匹配的定时器

void cancel(PendingIntent operation)

//注册一个新的延迟定时器

void set(int type, long triggerAtTime, PendingIntent operation)

//注册一个重复类型的定时器

void setRepeating(int type, long triggerAtTime, long interval, PendingIntent operation)

//注册一个非精密的重复类型定时器

void setInexactRepeating (int type, long triggerAtTime, long interval, PendingIntent operation)

//设置时区

void setTimeZone(String timeZone)

// 取消已经注册的与参数匹配的定时器

voidcancel(PendingIntent operation)

//注册一个新的延迟定时器

voidset(int type, long triggerAtTime, PendingIntent operation)

//注册一个重复类型的定时器

voidsetRepeating(int type, long triggerAtTime, long interval, PendingIntent operation)

//注册一个非精密的重复类型定时器

void setInexactRepeating (int type, long triggerAtTime, long interval, PendingIntent operation)

//设置时区

voidsetTimeZone(String timeZone)

定时器主要类型:

源码copy to clipboard打印?

public static final int ELAPSED_REALTIME

// 当系统进入睡眠状态时,这种类型的闹铃不会唤醒系统。直到系统下次被唤醒才传递它,该闹铃所用的时间是相对时间,是从系统启动后开始计时的,包括睡眠时 间,可以通过调用SystemClock.elapsedRealtime()获得。系统值是3 (0x00000003)。

public static final int ELAPSED_REALTIME_WAKEUP

//能唤醒系统,用法同ELAPSED_REALTIME,系统值是2 (0x00000002) 。

public static final int RTC

//当系统进入睡眠状态时,这种类型的闹铃不会唤醒系统。直到系统下次被唤醒才传递它,该闹铃所用的时间是绝对时间,所用时间是UTC时间,可以通过调用 System.currentTimeMillis()获得。系统值是1 (0x00000001) 。

public static final int RTC_WAKEUP

//能唤醒系统,用法同RTC类型,系统值为 0 (0x00000000) 。

Public static final int POWER_OFF_WAKEUP

//能唤醒系统,它是一种关机闹铃,就是说设备在关机状态下也可以唤醒系统,所以我们把它称之为关机闹铃。使用方法同RTC类型,系统值为4(0x00000004)。

publicstaticfinalintELAPSED_REALTIME

// 当系统进入睡眠状态时,这种类型的闹铃不会唤醒系统。直到系统下次被唤醒才传递它,该闹铃所用的时间是相对时间,是从系统启动后开始计时的,包括睡眠时 间,可以通过调用SystemClock.elapsedRealtime()获得。系统值是3(0x00000003)。

publicstaticfinalintELAPSED_REALTIME_WAKEUP

//能唤醒系统,用法同ELAPSED_REALTIME,系统值是2 (0x00000002) 。

publicstaticfinalintRTC

//当系统进入睡眠状态时,这种类型的闹铃不会唤醒系统。直到系统下次被唤醒才传递它,该闹铃所用的时间是绝对时间,所用时间是UTC时间,可以通过调用 System.currentTimeMillis()获得。系统值是1 (0x00000001) 。

publicstaticfinalintRTC_WAKEUP

//能唤醒系统,用法同RTC类型,系统值为 0 (0x00000000) 。

Public staticfinalintPOWER_OFF_WAKEUP

//能唤醒系统,它是一种关机闹铃,就是说设备在关机状态下也可以唤醒系统,所以我们把它称之为关机闹铃。使用方法同RTC类型,系统值为4(0x00000004)。

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

AlarmManager 生命周期:

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

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

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

如何使用AlarmManager?

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

源码copy to clipboard打印?

getActivity(Context, int, Intent, int)

getBroadcast(Context, int, Intent, int)

getService(Context, int, Intent, int)

getActivity(Context, int, Intent, int)

getBroadcast(Context, int, Intent, int)

getService(Context, int, Intent, int)

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

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

源码copy to clipboard打印?

/*

* Copyright (c) 2011, Yulong Information Technologies

* All rights reserved.

*

* @Project: AlarmTest

* @author: Robot

*/

package com.yfz;

import android.content.BroadcastReceiver;

import android.content.Context;

import android.content.Intent;

import android.util.Log;

/**

* @author Robot

* @weibo http://weibo.com/feng88724

* @date Nov 18, 2011

*/

public class ActionBroadCast extends BroadcastReceiver {

private static int num = 0;

/* (non-Javadoc)

* @see android.content.BroadcastReceiver#onReceive(android.content.Context, android.content.Intent)

*/

@Override

public void onReceive(Context context, Intent intent) {

// TODO Auto-generated method stub

Log.e("ActionBroadCast", "New Message !" + num++);

}

}

/*

* Copyright (c) 2011, Yulong Information Technologies

* All rights reserved.

*

*@Project: AlarmTest

*@author: Robot

*/

package com.yfz;

import android.content.BroadcastReceiver;

import android.content.Context;

import android.content.Intent;

import android.util.Log;

/**

* @author Robot

* @weibo http://weibo.com/feng88724

* @date Nov 18, 2011

*/

public class ActionBroadCast extends BroadcastReceiver {

private static int num = 0;

/* (non-Javadoc)

* @see android.content.BroadcastReceiver#onReceive(android.content.Context, android.content.Intent)

*/

@Override

public void onReceive(Context context, Intent intent) {

// TODO Auto-generated method stub

Log.e("ActionBroadCast", "New Message !" + num++);

}

}

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

源码copy to clipboard打印?

package com.yfz;

import android.app.Activity;

import android.app.AlarmManager;

import android.app.PendingIntent;

import android.content.Intent;

import android.os.Bundle;

public class AlarmTestActivity extends Activity {

/** Called when the activity is first created. */

@Override

public void onCreate(Bundle savedInstanceState) {

super.onCreate(savedInstanceState);

setContentView(R.layout.main);

AlarmManager am = (AlarmManager)getSystemService(ALARM_SERVICE);

PendingIntent pi = PendingIntent.getBroadcast(this, 0, new Intent(this, ActionBroadCast.class), Intent.FLAG_ACTIVITY_NEW_TASK);

long now = System.currentTimeMillis();

am.setInexactRepeating(AlarmManager.RTC_WAKEUP, now, 3000, pi);

}

}

package com.yfz;

import android.app.Activity;

import android.app.AlarmManager;

import android.app.PendingIntent;

import android.content.Intent;

import android.os.Bundle;

public class AlarmTestActivity extends Activity {

/** Called when the activity is first created. */

@Override

public void onCreate(Bundle savedInstanceState) {

super.onCreate(savedInstanceState);

setContentView(R.layout.main);

AlarmManager am = (AlarmManager)getSystemService(ALARM_SERVICE);

PendingIntent pi = PendingIntent.getBroadcast(this, 0, new Intent(this, ActionBroadCast.class), Intent.FLAG_ACTIVITY_NEW_TASK);

long now = System.currentTimeMillis();

am.setInexactRepeating(AlarmManager.RTC_WAKEUP, now, 3000, pi);

}

}

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

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

源码copy to clipboard打印?

<?xml version="1.0" encoding="utf-8"?>

<manifest xmlns:android="http://schemas.android.com/apk/res/android"

package="com.yfz"

android:versionCode="1"

android:versionName="1.0" >

<uses-sdk android:minSdkVersion="7" />

<application

android:icon="@drawable/ic_launcher"

android:label="@string/app_name" >

<activity

android:label="@string/app_name"

android:name=".AlarmTestActivity" >

<intent-filter >

<action android:name="android.intent.action.MAIN" />

<category android:name="android.intent.category.LAUNCHER" />

</intent-filter>

</activity>

<receiver

android:name="ActionBroadCast">

</receiver>

</application>

</manifest>

<?xml version="1.0" encoding="utf-8"?>

<manifest xmlns:android="http://schemas.android.com/apk/res/android"

package="com.yfz"

android:versionCode="1"

android:versionName="1.0" >

<uses-sdk android:minSdkVersion="7" />

<application

android:icon="@drawable/ic_launcher"

android:label="@string/app_name" >

<activity

android:label="@string/app_name"

android:name=".AlarmTestActivity" >

<intent-filter >

<action android:name="android.intent.action.MAIN" />

<category android:name="android.intent.category.LAUNCHER" />

</intent-filter>

</activity>

<receiver

android:name="ActionBroadCast">

</receiver>

</application>

</manifest>

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

做了一个例子,包含了使用AlarmManager的所有三种方式。已经上传至CSDN,下载地址: http://download.csdn.net/detail/feng88724/3812718 。 截图:

赞助本站

人工智能实验室

相关热词: AlarmManager

AiLab云推荐
展开

热门栏目HotCates

Copyright © 2010-2024 AiLab Team. 人工智能实验室 版权所有    关于我们 | 联系我们 | 广告服务 | 公司动态 | 免责声明 | 隐私条款 | 工作机会 | 展会港