Android复习之旅--BroadcastReceiver
来源:互联网 发布:农村淘宝网怎么开 编辑:程序博客网 时间:2024/06/03 13:03
在Android系统中,广播(Broadcast)是一种运用在应用程序之间传递消息的机制,广播接收者(BroadcastReceiver)是用来过滤、接收并响应广播的一类组件。通过广播接收者可以监听系统中的广播信息,在不同组件之间进行通信。
收音机 –> 广播接收者
电台基站 –> 广播
为了在某个事件发生后执行某些操作,所以应用中要定义一个广播接收者,用来监听某个事件。
广播接收者
创建
创建一个类继承BroadcastReceiver,让后重写onReceiver()方法onReceiver()方法运行在主线程,尽量不要再onReceiver()方法里进行耗时的操作,因为该方法的运行时间不能超过10秒,否则会ANR。复杂的业务处理可以开启一个服务或进入到另一个应用中。此方法运行完毕会自动销毁
public class MyBroadcastReceiver extends BroadcastReceiver { @Override public void onReceiver(Context context, Intent intent) { // TODO 事件发生后回调此方法 }}
注册
注册广播有两种方式:常驻型广播、非常驻型广播
- 常驻型广播
当应用程序关闭后,如果接收到其他应用程序发出的广播,那么该程序会自动重新启动。需要在清单文件中注册
<receiver android:name="cn.rixin.myreceiver.MyReceiver"> <intent-filter> <!-- 短信接收 --> <action android:name="android.provider.Telephony.SMS_RECEIVED"/> </intent-filter></receiver>
其他系统广播事件参考百度文库
- 非常驻型广播
依赖于注册广播的组件的生命周期,如在Activity中注册的广播接收者在Activity销毁后广播也会随之被移除。需要在代码中动态注册,最好在Activity的onResume()和onPause()方法中进行注册移除。
// 在onResume()方法中MyBroadcastReceiver receiver = new MyBroadcastReceiver();// 实例化过滤器并设置要过滤的广播String action = "android.provider.Telephony.SMS_RECEIVED";IntentFilter intentFilter = new IntentFilter(action);// 注册广播registerReceiver(receiver, intentFilter);// 在onPause()方法中// 移除广播unregisterReceiver(receiver);
安全升级
4.0以下的版本,任何广播接收者apk只要被装到手机就立刻生效。不管应用程序进程是否运行。
4.0以及4.0以上的版本,要求应用程序必须有UI界面(Activity) 广播接收者才能生效,如果用户点击了强行停止,应用程序就完全关闭了,广播接收者就失效了。如果用户没有点击过强行停止,即使应用程序进程不存在,也会自动的运行起来。
Android系统把许多常用的事件内置成了广播机制,一旦事件产生了就会向全系统发送一个广播消息。例如手机电量不足、有人给你发送了短信、你向外拨打了电话、手机启动完毕等等,系统都会发送一条相应的广播。当然,也可以自定义广播事件,主要用于应用内的通讯。
既然有广播接收者,那自然是得有广播才行的,因为得要知道广播后才能创建相应的广播接收者
广播
系统广播
Android系统中内置了许多的广播事件,只要是涉及到手机的基本操作(如开机关机、网络状态、拍照等)都会发送相应的广播Intent intent = new Intent();// 定义广播的事件类型intent.setAction("android.provider.Telephony.SMS_RECEIVED");// 可携带数据// intent.putExtra(key, value);// 发送广播sendBroadcast(intent);
系统中的广播事件 – 参考百度文库,或者自己google搜索
注意:有些广播事件是需要注册相应的权限的自定义广播
Intent intent = new Intent();// 定义广播的事件类型,字符串(自定义,最好包名+字符串)intent.setAction("com.rixin.sendBroadcast.FRX");// 可携带数据// intent.putExtra(key, value);// 发送广播sendBroadcast(intent);// 发送带权限的广播(权限自定义)sendBroadcast(intent, "com.rixin.sendBroadcast.KEY");// 广播接收者接收带权限的广播时需要注册权限<permission android:label="key" android:name="cn.rixin.sendBroadcast.KEY"></permission><uses-permission android:name="cn.rixin.sendBroadcast.KEY"/>
广播类型
Android系统中根据广播的执行顺序不同分为无序广播和有序广播。
- 无序广播(异步执行)
广播发送的时候,接收者接收没有先后顺序,无序广播不可以被拦截,不可以修改结果数据
中央人民广播电台:每晚7点整 –> sendBroadcast() —>所有人 有序广播(同步执行)
广播发送的时候,接收者是按照优先级先后顺序接收的,有序广播可以被拦截,可以修改结果数据。如果指定了最终的接收者,最终的接收者一定会收到消息。
中央向地方下达文件:中央–>省–>市–>乡–>农民Intent intent = new Intent();intent.setAction("cn.rixin.zhongyang.bokuan");// 发送无权限的有序广播sendOrderedBroadcast(intent, null);/** 发送带数据的有序广播 * * intent:意图 * receiverPermission:接收者的权限 * resultReceiver:指定接收者(设置为null后无论什么情况,都会接收到广播信息) * scheduler:消息处理者(一般设置为null) * initialCode:初始码 * initialData:数据 * initialExtras:intent里面携带的额外参数 */sendOrderedBroadcast(intent, "cn.rixin.orderbroadcast.shoukuan", null, null, 8, "拨款100万元", null);
高优先级的广播接收者接收到广播后可以对广播进行一些操作,比如修改数据,终止广播等。
setResultData(String data); // 修改有序广播中的数据
abortBroadcast(); // 终止有序广播有序广播的优先级是在intent-filter过滤器里设置priority属性,属性值范围在-1000~1000之间。如果两个广播接收者的优先级相同,则先注册的组件优先收到广播;如果两个应用监听了同一个广播事件并设置了相同的优先级,则先安装的应用优先接收到广播。
<receiver android:name="cn.rixin.orderbroadcast.ShengReceiver"> <intent-filter android:priority="1000"> <action android:name="cn.rixin.zhongyang.bokuan"/> </intent-filter></receiver>
最后,献上一些常用的系统广播事件吧
- 网络状态
<intent-filter> <action android:name="android.net.conn.CONNECTIVITY_CHANGE"></action></intent-filter>// 记得添加权限<uses-permission android:name="android.permission.ACCESS_NETWORK_STATE"/>
- 电量不足和电量充足
<intent-filter> <action android:name="Intent.ACTION_BATTERY_LOW"></action> <action android:name="Intent.ACTION_BATTERY_OKAY"></action></intent-filter>
- 插入耳机
<intent-filter> <action android:name="Intent.ACTION_HEADSET_PLUG"></action></intent-filter>// 记得添加权限<uses-permission android:name="android.permission.MODIFY_AUDIO_SETTINGS" />
- 开机,关机,重启设备
<intent-filter> <action android:name="android.intent.action.BOOT_COMPLETED"></action> <action android:name="Intent.ACTION_SHUTDOWN"></action> <action android:name="Intent.ACTION_REBOOT"></action></intent-filter>// 记得添加权限<uses-permission android:name="android.permission.RECEIVE_BOOT_COMPLETED" />
- 应用程序的安装、卸载、替换
<intent-filter> <action android:name="android.intent.action.PACKAGE_ADDED"></action> <action android:name="android.intent.action.PACKAGE_REMOVED"></action> <action android:name="android.intent.action.PACKAGE_REPLACED"></action> <!-- 数据的类型是一个apk的包 package:// --> <data android:scheme="package"></data></intent-filter>
- SD卡的状态(装载,卸载,不存在)
<intent-filter> <action android:name="android.intent.action.MEDIA_MOUNTED"></action> <action android:name="android.intent.action.MEDIA_REMOVED"></action> <action android:name="android.intent.action.MEDIA_UNMOUNTED"></action> <!-- 数据的类型是一个文件 --> <data android:scheme="file"></data></intent-filter>
- 屏幕锁屏和解锁
这是一组特殊的广播事件,接收这些广播事件采用清单文件Mainfast.xml配置是不生效的。需要在代码中动态注册
ScreenOnReceiver receiver = new ScreenOnReceiver()registerReceiver(receiver, new IntentFilter("android.intent.action.SCREEN_ON"));ScreenOffReceiver receiver = new ScreenOffReceiver()registerReceiver(receiver, new IntentFilter("android.intent.action.SCREEN_OFF"));// 记得移除unregisterReceiver(receiver);
如果这个广播事件经常发生,一般就不允许采用清单文件注册,只能采用代码注册的方式注册才会生效。程序运行生效–程序停止运行失效。
希望对您有所帮助,欢迎指(吐)正(嘈)
- Android复习之旅--BroadcastReceiver
- Android复习之BroadCastReceiver
- Android 复习笔记之图解BroadcastReceiver
- Android之旅六 BroadcastReceiver
- BroadCastReceiver复习
- (转载)Android学习之旅- BroadCastReceiver
- Android之Intent&BroadcastReceiver
- Android之Service&BroadCastReceiver
- Android之BroadcastReceiver
- android学习之-BroadcastReceiver
- Android之BroadcastReceiver
- Android白眉鹰王之BroadcastReceiver
- android之BroadcastReceiver实例
- Android之BroadcastReceiver组件
- Android之BroadcastReceiver分析
- Android之BroadcastReceiver
- Android之BroadcastReceiver
- Android之Service&BroadCastReceiver
- java 序列化和反序列化实现克隆
- 从B树、B+树、B*树谈到R 树
- 初学者之CSS学习(六)盒子模型
- 手机连接电脑MTP显示问号
- 求最大公约数和最小公倍数
- Android复习之旅--BroadcastReceiver
- 3、配置Maven环境
- Vuejs是什么
- virtualbox安装centos7
- iOS - 如何在iOS8.0系统以上使用指纹功能
- python
- Leetcode 62. Unique Paths和63. Unique Paths II
- http返回码状态
- org.apache.maven.archiver.MavenArchiver.getManifest解决方法