AlarmManager的学习与实现
2015-11-25 10:31
204 查看
综述
这个类提供了一种使用系统提供的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;
第二步:修改布局文件添加两个按钮,文件内容如下:
[html] view
plaincopy
<?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的广播的功能,当然还需要设置广播接收器,代码如下:
[java] view
plaincopy
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,代码如下:
[java] view
plaincopy
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文件中进行声明。
第六步:运行程序,如下图。
转载地址:/article/1421721.html
这个类提供了一种使用系统提供的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;
第二步:修改布局文件添加两个按钮,文件内容如下:
[html] view
plaincopy
<?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的广播的功能,当然还需要设置广播接收器,代码如下:
[java] view
plaincopy
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,代码如下:
[java] view
plaincopy
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文件中进行声明。
第六步:运行程序,如下图。
转载地址:/article/1421721.html
相关文章推荐
- Spark-1.0.0 standalone分布式安装教程
- HTTP协议各种状态代码
- 更换免开发证书账号出现的Your build settings specify a provisioning profile with the UUID"",however,no such provisioning profile was found
- thinkphp权限管理Rbac实例
- swiper笔记
- VS编译方式 \MT \MD \MTd \MDd
- 贝叶斯网络
- Git详解之六 Git工具
- "中文编程"是解决中国程序员编程效率的一个"银弹"?
- linux命令find应用
- 重温Java中的接口
- 监理工程师岁月--蓝精灵的帽子
- Dagger 依赖注入的使用(DI)
- 源码分析:Java堆的创建
- PHPCMS 当前栏目和子目录
- vue.js学习笔记
- Xcode 统计整个工程代码行数
- C/C++中printf和C++中cout的输出格式
- Linux 虚拟机之--KVM的安装和配置(一)
- sysctl.conf文件参数rp_filter