一、BroadcastReceiver简介
1.BroadcastReceiver是Android四大组件之一。一般的都要在清单文件中进行静态注册。但是只有广播接收者可以在java代码中进行动态注册
2.BroadcastReceiver是用于接收广播的组件,用于组件与组件之间进行通信,可以跨应用程序传递
3.广播的发送适用场合:发送频率低的情况使用,数据量小的时候使用,因为intent不能携带太大的数据。
二、接收广播
2.1静态注册广播接收者
1 .在清单文件中进行配置
2.静态注册的广播的程序运行一次之后,以后能一直保持广播接收的状态,只要有对应的广播就能接收它的广播信息
2.2 动态注册广播接收者
- 动态注册的广播只有在程序运行中才能接收广播
- 首先写一个自己接收类extend BroadcastReceiver类
2.1实现其中的onReceive()方法,在此方法内我们可以获取随广播而来的intent中的数据
2.2判断intent.getAction()是否和所需的action相等
2.2.1 如果相等,说明状态发生了改变
2.2.2 根据联网管理器对象来获得对应的网络状态
2.2.3 在对应的状态下使用handler来发送消息
3.写一个注册广播的方法
3.1 new一个自定义的广播接收类对象
3.2 new一个IntentFilter对象
3.3 filter.addAction(ConnectivityManager.CONNECTIVITY_ACTION)
3.4 registerReceiver(广播接收类对象,filter);进行注册- 注册广播
在Activity初始化的时候写上注册广播相应的方法,完成广播的注册
5.需要在特定的地方解除注册
5.1 registerReceiver是ContextWrapper类中的方法,Activity和Service都继承了ContextWrapper,所以可以直接调用,在实际应用中,我们在Activity和Service中注册了一个BroadcastReceiver,当这个Activity或者Service被销毁是,如果没有解除广播的注册,系统会报一个异常,提示我们忘记解除注册
5.2 一般在页面销毁时进行接触注册 unregisterReceiver(自定义广播类的对象);
6.监听网络的实例代码
- 注册广播
public class NetBroadcastReceiver extends BroadcastReceiver {
@Override
public void onReceive(Context context, Intent intent) {
// 如果相等的话就说明网络状态发生了变化
if (intent.getAction().equals(ConnectivityManager.CONNECTIVITY_ACTION)) {
int netMobile = NetUtil.getNetWorkState(context);
if (netMobile == 1) {
handler.sendEmptyMessage(500);
// Toast.makeText(LiveActivity.this, "无线", Toast.LENGTH_SHORT).show();
} else if (netMobile == 0) {
// Toast.makeText(LiveActivity.this, "移动", Toast.LENGTH_SHORT).show();
handler.sendEmptyMessage(500);
} else if (netMobile == -1) {
handler.sendEmptyMessage(501);
// Toast.makeText(LiveActivity.this, "当前网络不可用,请检查后重试", Toast.LENGTH_SHORT).show();
}
}
}
}
/**
* 没有连接网络
*/
private static final int NETWORK_NONE = -1;
/**
* 移动网络
*/
private static final int NETWORK_MOBILE = 0;
/**
* 无线网络
*/
private static final int NETWORK_WIFI = 1;
public static int getNetWorkState(Context context) {
// 得到连接管理器对象
ConnectivityManager connectivityManager = (ConnectivityManager) context.getSystemService(Context.CONNECTIVITY_SERVICE);
NetworkInfo activeNetworkInfo = connectivityManager.getActiveNetworkInfo();
if (activeNetworkInfo != null && activeNetworkInfo.isConnected()) {
if (activeNetworkInfo.getType() == (ConnectivityManager.TYPE_WIFI)) {
return NETWORK_WIFI;
} else if (activeNetworkInfo.getType() == (ConnectivityManager.TYPE_MOBILE)) {
return NETWORK_MOBILE;
}
} else {
return NETWORK_NONE;
}
return NETWORK_NONE;
}
@SuppressLint("HandlerLeak")
private Handler handler = new Handler() {
@Override
public void handleMessage(Message msg) {
super.handleMessage(msg);
switch (msg.what) {
case 500:
netTag = 1;
break;
case 501:
netTag = 2;
break;
}
}
};
//在需要的位置判断netTag的值,来取得是否联网的状态```
/**
* 注册广播
*/
private void registBroadcast() {
receiver = new NetBroadcastReceiver();
IntentFilter filter = new IntentFilter();
filter.addAction(ConnectivityManager.CONNECTIVITY_ACTION);
registerReceiver(receiver, filter);
}
2.3 关于广播接收者优先级的说明
1.在静态代码块中定义
<intent-filter android:priority="xxx">
2.动态java代码设置
filter.setPriority(...)
3.优先级的值越大优先级越高
3.1 网上说priority的最大值是1000,但是有其他人说是2147483647
3.2 优先级的范围是:-2147483647到2147483647 刚好它的长度范围是Integer类型数据的最大值4294967296(2的32次方)
三、发送广播
3.1普通广播(无序广播)
1.无序广播对于多个接收者来说是完全异步的,通常每个接收者都无需等待即可接收到广播,接收者之间不会有影响,但是对于这种无序广播来说,接收者无法终止广播,即无法阻止其他接收者的接收动作
2. sendBroadcast(intent)
Intent intent =new Intent(“。。。。。。”)
intent.putExtra(“xxx”,"xxxxx")
sendBroadcast(intent);
3.不能延迟
4.不能被拦截
3.2有序广播
1.有序广播 每次发送到优先级高的接收者哪里,然后由优先级高的接收者在传播到优先级低的接收者那里,优先级高的接收者有能力终止这个广播,优先级可以在接收者注册时进行设置(静态和动态)
2.setOrderdBroadcast(intent,permission)permission一般为null,表明不需要额外的权限,如果不为空,所有接收方必须有这个权限
3.可以延迟
4.可以被拦截 拦截方法
abortBroadcast(); //在接收者的OnReceive()中拦截
最后 作者要说,这是我在简书上写的第一篇文章了,感觉也不太会用,有写的不对的,欢迎指出