广播接收者Receiver
一,动态创建网络状态监控
思路:
1:需要注册一个广播接收者,registerReceiver()需要两个参数
public Intent registerReceiver(
BroadcastReceiver receiver, IntentFilter filter) {//接收者,过滤器(需要接收的内容)
return mBase.registerReceiver(receiver, filter);
}
2:参数一,接收者。新建一个NetworkChanceReceiver内部类,继承于BroadcastReceiver,并重写执行方法onReceive(){方法体中就是接收后要做的事情};
3.参数二,目的过滤器。创建过滤器实例,并addAction("要监听的广播信息");
4:动态注册的广播接收器需要手动取消。onDestroy()方法中的unregisterReceiver(传入取消的过滤器)方法;
public class broadcastReceiverDemo extends Activity {
private IntentFilter intentFilter;
private NetworkChanceReceiver networkChangeReceiver;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.broadcase_recever_layout);
intentFilter =new IntentFilter();//创建intentFilter(目的过滤器)实例
intentFilter.addAction("android.net.conn.CONNECTIVITY_CHANGE");//添加系统广播的网络变化的值
networkChangeReceiver = new NetworkChanceReceiver();//创建NetworkChanceReceiver实例
registerReceiver(networkChangeReceiver,intentFilter);//调用registerReceiver()方法进行注册,将NetworkChangeReceiver的实例
// 和 IntentFilter 的实例都传了进去,这样NetworkChangeReceiver就会收到所有值为android.net.conn.CONNECTIVITY_CHANGE的广播 播
}
@Override
protected void onDestroy() {//动态注册的广播接收器一定都要取消注册才行,在onDestroy()方法中通过调用unregisterReceiver()方法来实现的
super.onDestroy();
unregisterReceiver(networkChangeReceiver);
}
class NetworkChanceReceiver extends BroadcastReceiver{//定义内部类NetworkChanceReceiver,继承于BroadcastReceiver
@Override
public void onReceive(Context context, Intent intent) {//当网络发生改变的时候就会执行onReceiver里的代码
ConnectivityManager connectivityManager = (ConnectivityManager) getSystemService(Context.CONNECTIVITY_SERVICE);
//获取系统服务的ConnectivityManager(网络连接管理器)实例
NetworkInfo networkInfo = connectivityManager.getActiveNetworkInfo();
//通过ConnectivityManager获取网络信息,赋值给networkInfo
if (networkInfo != null && networkInfo.isAvailable()) {
//通过isAvailable()判断网络是否联通
Toast.makeText(context, "网络连接可用",
Toast.LENGTH_SHORT).show();
} else {
Toast.makeText(context, "请检查网络连接",
Toast.LENGTH_SHORT).show();
}
}
}
}
调用网络信息需要系统权限
<uses-permission android:name="android.permission.ACCESS_NETWORK_STATE"/>
二,静态创建注册开机监控事件
1.静态创建启动监控的类BootCompleteReceiver 继承于BroadcastReceiver
重写onReceive()方法;
2.在ManiFest中注册权限
广播组件开机启动权限
<uses-permission android:name="android.permission.RECEIVE_BOOT_COMPLETED" />
注册广播接收器和要接收的广播
<receiver android:name=".broadReceiver.BootCompleteReceiver">
<intent-filter>
<action android:name="android.intent.action.BOOT_COMPLETED" />
</intent-filter>
</receiver>
三,系统广播大全
//关闭或打开飞行模式时的广播
Intent.ACTION_AIRPLANE_M; //充电状态,或者电池的电量发生变化;//电池的充电状态、电荷级别改变,不能通过组建声;
Intent.ACTION_BATTERY_CH; //表示电池电量低
Intent.ACTION_BATTERY_LO; //表示电池电量充足
Intent.ACTION_BATTERY_OK; //关闭或打开飞行模式时的广播
Intent.ACTION_AIRPLANE_MODE_CHANGED; //充电状态,或者电池的电量发生变化//电池的充电状态、电荷级别改变,不能通过组建声明接收这个广播,只有通过Context.registerReceiver()注册
Intent.ACTION_BATTERY_CHANGED; //表示电池电量低
Intent.ACTION_BATTERY_LOW; //表示电池电量充足,即从电池电量低变化到饱满时会发出广播
Intent.ACTION_BATTERY_OKAY; //在系统启动完成后,这个动作被广播一次(只有一次)。
Intent.ACTION_BOOT_COMPLETED; //按下照相时的拍照按键(硬件按键)时发出的广播
Intent.ACTION_CAMERA_BUTTON; //当屏幕超时进行锁屏时,当用户按下电源按钮,长按或短按(不管有没跳出话框),进行锁屏时,android系统都会广播此Action消息
Intent.ACTION_CLOSE_SYSTEM_DIALOGS; //设备当前设置被改变时发出的广播(包括的改变:界面语言,设备方向,等,请参考Configuration.java)
Intent.ACTION_CONFIGURATION_CHANGED; //设备日期发生改变时会发出此广播
Intent.ACTION_DATE_CHANGED; //设备内存不足时发出的广播,此广播只能由系统使用,其它APP不可用
Intent.ACTION_DEVICE_STORAGE_LOW; //设备内存从不足到充足时发出的广播,此广播只能由系统使用,其它APP不可用
Intent.ACTION_DEVICE_STORAGE_OK; //发出此广播的地方frameworks\base\services\java\com\android\server\DockObserver.java
Intent.ACTION_DOCK_EVENT; //移动APP完成之后,发出的广播(移动是指:APP2SD)
Intent.ACTION_EXTERNAL_APPLICATIONS_AVAILABLE; //正在移动APP时,发出的广播(移动是指:APP2SD)
Intent.ACTION_EXTERNAL_APPLICATIONS_UNAVAILABLE; //Gtalk已建立连接时发出的广播
Intent.ACTION_GTALK_SERVICE_CONNECTED; //Gtalk已断开连接时发出的广播
Intent.ACTION_GTALK_SERVICE_DISCONNECTED; //在耳机口上插入耳机时发出的广播
Intent.ACTION_HEADSET_PLUG; //改变输入法时发出的广播
Intent.ACTION_INPUT_METHOD_CHANGED; //设备当前区域设置已更改时发出的广播
Intent.ACTION_LOCALE_CHANGED; //表示用户和包管理所承认的低内存状态通知应该开始。
Intent.ACTION_MANAGE_PACKAGE_STORAGE; //未正确移除SD卡(正确移除SD卡的方法:设置--SD卡和设备内存--卸载SD卡),但已把SD卡取出来时发出的广播 ,扩展介质(扩展卡)已经从 SD 卡插槽拔出,但是挂载点 (mount point) 还没解除 (unmount)
Intent.ACTION_MEDIA_BAD_REMOVAL; //按下"Media Button" 按键时发出的广播,假如有"Media Button" 按键的话(硬件按键)
Intent.ACTION_MEDIA_BUTTON; //插入外部储存装置,比如SD卡时,系统会检验SD卡,此时发出的广播?
Intent.ACTION_MEDIA_CHECKING; //已拔掉外部大容量储存设备发出的广播(比如SD卡,或移动硬盘),不管有没有正确卸载都会发出此广播, 用户想要移除扩展介质(拔掉扩展卡)。
Intent.ACTION_MEDIA_EJECT; //插入SD卡并且已正确安装(识别)时发出的广播, 扩展介质被插入,而且已经被挂载。
Intent.ACTION_MEDIA_MOUNTED; //拓展介质存在,但使用不兼容FS(或为空)的路径安装点检查介质包含在Intent.mData领域。
Intent.ACTION_MEDIA_NOFS; //外部储存设备已被移除,不管有没正确卸载,都会发出此广播, 扩展介质被移除。
Intent.ACTION_MEDIA_REMOVED; //广播:已经扫描完介质的一个目录
Intent.ACTION_MEDIA_SCANNER_FINISHED; //请求媒体扫描仪扫描文件并将其添加到媒体数据库。
Intent.ACTION_MEDIA_SCANNER_SCAN_FILE; //广播:开始扫描介质的一个目录
Intent.ACTION_MEDIA_SCANNER_STARTED; // 广播:扩展介质的挂载被解除 (unmount),因为它已经作为 USB 大容量存储被共享。
Intent.ACTION_MEDIA_SHARED; Intent.ACTION_MEDIA_UNMOUNTABLE;// // 广播:扩展介质存在,但是还没有被挂载 (mount)
Intent.ACTION_MEDIA_UNMOUNTED Intent.ACTION_NEW_OUTGOING_CALL; //成功的安装APK之后//广播:设备上新安装了一个应用程序包。//一个新应用包已经安装在设备上,数据包括包名(最新安装的包程序不能接收到这个广播)
Intent.ACTION_PACKAGE_ADDED; //一个已存在的应用程序包已经改变,包括包名
Intent.ACTION_PACKAGE_CHANGED; //清除一个应用程序的数据时发出的广播(在设置--应用管理--选中某个应用,之后点清除数据时?)//用户已经清除一个包的数据,包括包名(清除包程序不能接收到这个广播)
Intent.ACTION_PACKAGE_DATA_CLEARED; //触发一个下载并且完成安装时发出的广播,比如在电子市场里下载应用?
Intent.ACTION_PACKAGE_INSTALL; //成功的删除某个APK之后发出的广播, 一个已存在的应用程序包已经从设备上移除,包括包名(正在被安装的包程序不能接收到这个广播)
Intent.ACTION_PACKAGE_REMOVED; //替换一个现有的安装包时发出的广播(不管现在安装的APP比之前的新还是旧,都会发出此广播?)
Intent.ACTION_PACKAGE_REPLACED; //用户重新开始一个包,包的所有进程将被杀死,所有与其联系的运行时间状态应该被移除,包括包名(重新开始包程序不能接收到这个广播)
Intent.ACTION_PACKAGE_RESTARTED; //插上外部电源时发出的广播
Intent.ACTION_POWER_CONNECTED; //已断开外部电源连接时发出的广播
Intent.ACTION_POWER_DISCONNECTED; Intent.ACTION_PROVIDER_CHANGED;// //重启设备时的广播
Intent.ACTION_REBOOT; //屏幕被关闭之后的广播
Intent.ACTION_SCREEN_OFF; //屏幕被打开之后的广播
Intent.ACTION_SCREEN_ON; //关闭系统时发出的广播
Intent.ACTION_SHUTDOWN; //时区发生改变时发出的广播
Intent.ACTION_TIMEZONE_CHANGED; //时间被设置时发出的广播
Intent.ACTION_TIME_CHANGED; //广播:当前时间已经变化(正常的时间流逝), 当前时间改变,每分钟都发送,不能通过组件声明来接收
,只有通过Context.registerReceiver()方法来注册
Intent.ACTION_TIME_TICK; //一个用户ID已经从系统中移除发出的广播
Intent.ACTION_UID_REMOVED; //设备已进入USB大容量储存状态时发出的广播?
Intent.ACTION_UMS_CONNECTED; //设备已从USB大容量储存状态转为正常状态时发出的广播?
Intent.ACTION_UMS_DISCONNECTED; Intent.ACTION_USER_PRESENT;// //设备墙纸已改变时发出的广播
Intent.ACTION_WALLPAPER_CHANGED;
四,自定义系统广播
1.新建发送标准广播意图
Intent intent = new Intent("com.cenzhongman.myapplication.MY_BROADCAST");
sendBroadcast(intent);
通过sendBroadcast( );发出了标准广播
2.发送有序广播
(1)发出有序广播
Intent intent = new Intent("com.cenzhongman.myapplication.MY_BROADCAST");
sendOrderedBroadcast(intent,null);
第二个参数是一个与权限相关的字符串,这里传入 null 就行了。 (有机会再搞明白)
3.接收标准广播
1.创建广播接收者类MyBoradcastReceiver继承于BoradcastReceiver
2.注册标准接收者权限
<receiver android:name=".broadReceiver.MyBroadcastReceiver">
<intent-filter>
<action android:name="com.cenzhongman.myapplication.MY_BROADCAST"/>
</intent-filter>
</receiver>
4.接收有序接收者
1.创建广播接收者类MyBoradcastReceiver继承于BoradcastReceiver
2.注册有序接收者权限(注册优先级)
<receiver android:name=".broadReceiver.MyBroadcastReceiver">
<intent-filter android:priority="100">
<action android:name="com.cenzhongman.myapplication.MY_BROADCAST"/>
</intent-filter>
</receiver>
获得优先级的接收者可以选择是否允许广播继续传递,数越大优先级别越高,最大值是2147483647,默认优先级是1;
abortBroadcast();
在onReceiver中加入abortBroadcast(); 可以拦截广播,不继续传播。
四,自定义本地广播(不能静态注册)
基本上就和的动态注册广播接收器以及发送广播的代码是一样。只不过现在
首先是通过 LocalBroadcastManager的 getInstance()方法得到了它的一个实例,
然后在注册广播接收器的时候调用的是 LocalBroadcastManager的 registerReceiver()方法,
在发送广播的时候调用的是 LocalBroadcastManager 的 sendBroadcast()方法,
取消注册调用的是localBroadcastManager的unregisterReceiver方法
仅此而已。这里我们在按钮的点击事件里面发出了一条自己的广播,然后在 LocalReceiver 里去接收这条广播。
广播接收者Receiver的更多相关文章
- android 监听去电实现ip拨号 广播接收者
利用广播实现ip拨号 布局文件: <?xml version="1.0" encoding="utf-8"?> <LinearLayout x ...
- 广播接收者案例_ip拨号器
(1)定义一个类继承BroadCastReceiver public class OutGoingCallReceiver extends BroadcastReceiver { //当接收到外拨电话 ...
- Android笔记(五):广播接收者(Broadcast Receiver)
Android有四大组件,分别为:Activity(活动).Service(服务).Content Provider(内容提供器).Broadcast Receiver(广播接收者). 引入广播的目的 ...
- Android开发学习—— Broadcast广播接收者
现实中:电台要发布消息,通过广播把消息广播出去,使用收音机,就可以收听广播,得知这条消息.Android中:系统在运行过程中,会产生许多事件,那么某些事件产生时,比如:电量改变.收发短信.拨打电话.屏 ...
- Android - 广播接收者 - BroadcastReceiver
BroadcastReceiver 介绍: 广播是一种广泛运用的在应用程序之间传输信息的机制 .而 BroadcastReceiver 是对发送出来的广播 进行过滤接收并响应的一类组件 接受一种或者多 ...
- 广播发送者&广播接收者介绍
1.广播接收者 广播接收者简单地说就是接收广播意图的Java类,此Java类继承BroadcastReceiver类,重写: public void onReceive(Context context ...
- Android广播接收者应用(电话拦截器)
一.电话拦截器应用说明 在我们输入完电话号码并拨打电话时,系统会发出一个有序广播(action="android.intent.action.NEW_OUTGOING_CALL") ...
- android学习日记19--四大组件之BroadcastReciver(广播接收者)
二.BroadcastReciver(广播接收者) 1.简述 BroadcastReciver位于android.content包下,主要用于对广播消息(Intent)的过滤并响应的控件.可以理解为全 ...
- android91 代码注册广播接收者
Activity: package com.itheima.register; import android.os.Bundle; import android.app.Activity; impor ...
随机推荐
- 【转】关于Java的Daemon线程的理解
原文地址:http://www.cnblogs.com/ChrisWang/archive/2009/11/28/1612815.html 关于Java的Daemon线程的理解 网上对Java的Dae ...
- linux环境变量的设置
linux中环境变量分为系统环境变量和用户环境变量(和window中一样),系统环境变量对所有系统用户都有效,用户环境变量只对当前用户有效,我们以ubuntu为例说明 用户环境变量 用户环境变量通常存 ...
- 编程中Foo, Bar 到底什么意思?
1 前言 在很多国外计算机书本和一些第三份开源软件的Demo中经常用到两个英文单词Foo,Bar.这到底是什么意思呢?从步入屌丝界的IT生活见到这两个单词到现在我还是不知道这两个单词的真正含义,今天有 ...
- [mysql]三种方法为root账户指定密码
前言:前段时间把mysql安装后一直没管它,当时就在奇怪为什么mysql登陆不要密码,原来一直用的超用户账户登陆的(简称超级用户) 其实只怪自己太无知,之前一直用的phpbydamin进行的数据库的可 ...
- JAVA中内部类和同文件非内部类的总结
java文件的顶层类(即非其它类的内部类),可见范围只有public和非public(包内可见)2种,不能用private或protected修饰.1个Java文件只能有一个public类,且必须与文 ...
- 科学计算器(JAVA实现)
前记: 大二学 Java 的时候写的,现在贴上来,只为留念. 再翻代码,自己看着都头疼.一重重的 if 嵌套,当时写得费劲,现在看着更费劲. 代码思想: 代码的大致思想是这样: 首先定义一个算式字符串 ...
- VPS搭建VPN、BLOG
FQ的正确姿势,你掌握了多少?老司机带你去墙外看看,来开车了坐稳! 购买VPS主机(服务端) 推荐性价比较高的VPS 搬瓦工https://bandwagonhost.com/ 上面的链接如果你打不开 ...
- C#.NET 大型企业信息化系统集成快速开发平台 4.2 版本 - 多软件系统集成缓存体系改进
由于我们同时开发多个大型应用系统同时系统有大量用户.高并发用户,平时访问系统的用户数量就有3万多人在线.需要对几十个系统进行持续优化改进,同时要增强信息系统的各种安全性. 如此多的系统.如此多的用户, ...
- Charles 如何抓取https数据包
Charles可以正常抓取http数据包,但是如果没有经过进一步设置的话,无法正常抓取https的数据包,通常会出现乱码.举个例子,如果没有做更多设置,Charles抓取https://www.bai ...
- Java 基础【12】 压缩与解压缩
Java.util.zip 提供用于读写标准 ZIP 和 GZIP 文件格式的类. 还包括使用 DEFLATE 压缩算法(用于 ZIP 和 GZIP 文件格式)对数据进行压缩和解压缩的类. 依赖 Jd ...