Broadcast Receiver(接收器)可以用来监听Broadcast Intent。要使用Broadcast Receiver能够接收广播,需要对其进行注册,可以使用代码注册和在mainifest中注册(静态注册和动态注册)。
对于包含mainfest接收器的应用程序,在intent被广播出去的时候,应用程序不一定非要处于运行状态才能执行接收,当匹配的intent被广播出去的时候,它们会被自动地启动。对于资源管理来说,这点是非常优秀的,因为它可以让你创建出事件驱动的应用程序,即使它们被关闭或者销毁了,也仍然能够对广播事件作出响应。
要创建一个新的Broadcast Receiver,需要扩展BroadcastReceiver类并重写onReceive事件程序。在onReceive处理程序必须在五秒内完成,否则会报Force Close对话框。
一般情况下,Broadcast Receiver使用来更新内容、启动service、更新activity ui,或者使用notification manager 来通知用户。
首先先了解一下intent,intent是一种消息传递机制,可以在应用程序内使用,也可以在应用程序间使用,显式intent就是普通的启动activity,隐式intent需要指定一个要执行的动作,例如打电话。
1、动态注册实现:
这里是添加的action事件是当电量改变的时候发送广播。
mmyReceiver = new MyReceiver();
IntentFilter intentfilter = new IntentFilter();
// intentfilter.addAction(TEST_DYNAMIC);
intentfilter.addAction(Intent.ACTION_BATTERY_CHANGED);
registerReceiver(mmyReceiver, intentfilter);
处理中是显示电量,TEST_DYNAMIC是自定义的 ,可随意写
private static String TEST_DYNAMIC = "com.test.TEST_DYNAMIC";
class MyReceiver extends BroadcastReceiver {
@Override
public void onReceive(Context context, Intent intent) {
int level = intent.getIntExtra("level", 0);//电量 0~100
tv.setText(level+"");
if (intent.getAction().equals(TEST_DYNAMIC)) {
Toast.makeText(getApplication(), "onReceive", Toast.LENGTH_SHORT).show();
}
}
}
发送广播,当自定义的时候可以使用,监测电量改变就不需要了
Intent onIntent = new Intent(TEST_DYNAMIC);
sendBroadcast(onIntent);
2、静态注册实现:
首先先在mainfest中注册,priority是优先级,越大优先级越高
接收代码实现:
package com.example.apple.intenttest;
import android.content.BroadcastReceiver;
import android.content.Context;
import android.content.Intent;
import android.widget.Toast;
import com.example.apple.intenttest.utils.Utils;
/**
* Created by apple on 17/4/9.
*/
public class MyReceiver extends BroadcastReceiver {
@Override
public void onReceive(Context context, Intent intent) {
if (intent.getAction().equals(Utils.NOTIFICATION)) {
String data = intent.getStringExtra("receiver");
Toast.makeText(context, "MyReceiver=" + data, Toast.LENGTH_SHORT).show();
}
}
}
代码中发送广播
//静态广播
Intent intent = new Intent(Utils.NOTIFICATION);
intent.putExtra("receiver","receiver");
sendBroadcast(intent);
3、使用完后都要注销广播在onDestroy中使用
@Override
protected void onDestroy() {
if (mmyReceiver != null) {
unregisterReceiver(mmyReceiver);
mmyReceiver = null;
}
super.onDestroy();
}
4、根据广播的发送方式有
根据广播的发送方式,可以将其分为以下几种类型:
1.Normal Broadcast:普通广播
2.System Broadcast: 系统广播
3.Ordered broadcast:有序广播
4.Sticky Broadcast:粘性广播(在 android 5.0/api 21中deprecated,不再推荐使用,相应的还有粘性有序广播,同样已经deprecated)
5.Local Broadcast:局部广播管理器
系统广播
Android系统中内置了多个系统广播,只要涉及到手机的基本操作,基本上都会发出相应的系统广播。如:开启启动,网络状态改变,屏幕关闭与开启,电量改变等等。每个系统广播都具有特定的intent-filter,其中主要包括具体的action,系统广播发出后,将被相应的BroadcastReceiver接收。系统广播在系统内部当特定事件发生时,有系统自动发出。
有序广播
当BroadcastReceiver 接收intent的顺序十分重要的时候,特别需要接收器能够影响将来的接收器收到的Broadcast Intent时,可以使用sendOrderedBroadcast方法,如下:
String requestPermission = "com.paad.MY_BROADCAST_PERMISSION";
sendOrderedBroadcast(intent,requestPermission);
Sticky Intent是Broadcast Intent 的有用变体,可以保存它们最后一次广播的值,并且当有一个新的接收器被注册为该广播时,它们会把这些值作为intent传回。
IntentFilter battery = new IntentFilter(Intent.ACTION_BATTERY_CHANGED);
Intent current = registerReceiver(null,battery);
sendStickyBroadcast(current);
要删除一个Sticky Intent ,可以调用removeStickyBroadcast,并出入要删除的Sticky intent.
removeStickyBroadcast(onIntent);
Local Broadcast Manager:(局部广播管理器)
Local Broadcast Manager包含在android support library中,用于简化注册Broadcast intent,以及在应用程序内的组件之间发送broadcast intent的工作。
因为局部广播的作用域要小一些,所以使用Load Broadcast Manager 比发送全局广播更加高效。也可以确保应用程序外部的任何组件都接收不到你的广播,所以不会有私人数据或敏感数据泄露的风险。
LocalBroadcastManager lbm = LocalBroadcastManager.getInstance(this);
lbm.registerReceiver(new BroadcastReceiver() {
@Override
public void onReceive(Context context, Intent intent) {
}
},new IntentFilter(LOCAL_ACTION));
要发送一个局部广播可以使用
lbm.sendBroadcast(new Intent(LOCAL_ACTION));
Local Broadcast Manager还包含一个用于同步的sendBroadSync方法,知道每个已注册的接收器都接收到广播后才接触阻塞。