Android-Broadcast 太过爱你忘了你带给我的痛 2022-04-12 14:20 215阅读 0赞 # **分类: ** # **广播有两个角色,一个是广播发送者,另外一个是广播接收者。** # **类型:** # ** ****按照类型分为两种,一种是全局广播,另外一种是本地广播。** ## **全局广播:** ## ** 发出的广播可以被其他任意的应用程序接收,或者可以接收来自其他任意应用程序的广播。** ## **本地广播:** ## ** 只能在应用程序的内部进行传递的广播,广播接收器也只能接收内部的广播,不能接受其他应用程序的广播。** # **全局广播的使用:** # ## **一、定义一个广播类** ## ** 在使用广播之前(也就是接收广播),我们需要定义一个类,让它继承BroadcastReceiver,复写其中的onrecevie方法,onreceieve方法中就是我们想要广播接收器收到广播之后需要处理的操作。** public class myreceiver extends BroadcastReceiver { @Override public void onReceive(Context context, Intent intent) { //在这里写上相关的处理代码,一般来说,不要此添加过多的逻辑或者是进行任何的耗时操作 //因为广播接收器中是不允许开启多线程的,过久的操作就会出现报错 //因此广播接收器更多的是扮演一种打开程序其他组件的角色,比如创建一条状态栏通知,或者启动某个服务 } } ## **二、对广播进行注册** ## **注册的方式有两种,一种是动态注册(使用java代码),另外一种则是静态注册(在AndroidMainFest文件中定义)** ### **动态注册:** ### **①在相关的activity文件中new一个刚才我们定义的广播类** **②new一个intentFilter类,调用其的setAction方法,参数中传入相关值的action** **③调用context.registerReceiver方法进行注册,方法的第一个参数为广播类,第二个则是intentFilter类** private myreceiver recevier; private IntentFilter intentFilter; @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.activity_main); recevier = new myreceiver(); intentFilter = new IntentFilter(); intentFilter.addAction("android.net.conn.CONNECTIVITY_CHANGE"); //当网络发生变化的时候,系统广播会发出值为android.net.conn.CONNECTIVITY_CHANGE这样的一条广播 registerReceiver(recevier,intentFilter); } **这里我们将广播类与intentFilter类声明为全局变量,便于之后的注册与注销** **需要注意的是,动态注册的广播接收器一定要注销,在onDestroy方法中调用unregisterReceiver(recevier);** ### **静态注册:** ### **①在AndroidMainFest中的application标签下加上receiver的子标签** **②与通过name属性指定注册一个广播类,也就是我们刚才定义的那个广播类,还有enabled与exported属性,enabled代表是否启用这个广播接收器,exported属性表示是否允许这个广播接收器接受本程序以外的广播(这两步可以通过Android Studio自动完成)** **③之后在receiver标签下加上intent-filter标签,设置其的action** <receiver android:name=".myreceiver" android:exported="true" android:enabled="true"> <intent-filter> <action android:name="android.intent.action.BOOT_COMPLETED"> //开机完成后系统广播发出的一条值为android.intent.action.BOOT_COMPLETED的广播 </intent-filter> </receiver> **ps:使用android studio可以快速实现第二步,操作如下:** **右键,打开new,选择other,再选择BroadcastReceiver** ![watermark_type_ZmFuZ3poZW5naGVpdGk_shadow_10_text_aHR0cHM6Ly9ibG9nLmNzZG4ubmV0L3dlaXhpbl80MDc4MzMxNQ_size_16_color_FFFFFF_t_70][] ** classname就是填写之前的那个广播类,默认exported和enabled两个属性都是true,不勾选的话就是false** ## ![watermark_type_ZmFuZ3poZW5naGVpdGk_shadow_10_text_aHR0cHM6Ly9ibG9nLmNzZG4ubmV0L3dlaXhpbl80MDc4MzMxNQ_size_16_color_FFFFFF_t_70 1][] ## **这个功能就是生成一个广播类,并且为其实现静态注册,当然,就是实现了创建一个广播类与静态注册的前两步,我们还需要完成第三步,填写intent-filter标签中的action的值。** ## **三、在清单文件里声明权限** ## ** 注册完之后,我们还需要在AndroidMAinFest中声明相关的权限,这个不用多说了,这里贴一张图** ![watermark_type_ZmFuZ3poZW5naGVpdGk_shadow_10_text_aHR0cHM6Ly9ibG9nLmNzZG4ubmV0L3dlaXhpbl80MDc4MzMxNQ_size_16_color_FFFFFF_t_70 2][] **最后说一下动态注册与静态注册的区别** ![watermark_type_ZmFuZ3poZW5naGVpdGk_shadow_10_text_aHR0cHM6Ly9ibG9nLmNzZG4ubmV0L3dlaXhpbl80MDc4MzMxNQ_size_16_color_FFFFFF_t_70 3][] ## **使用广播发送者发送自定义广播** ## Intent intent = new Intent(); intent.setAction("com.example.mymessage"); //Intent intent = new Intent("com,example.mymessage"); //也可以像注释这样写 sendBroadcast(intent);//发送标准广播 sendOrderedBroadcast(intent,null);//发送有序广播 //意思就是发送值为com.example.mymessage的这样一条广播 **之后,我们把intentfilter中的action改为上面的com.example.mymessage可以了,但是,测试的时候我们会发现不能体现出有序广播的定义,我们需要给广播接收器设置一下优先度** **如果使用的是动态注册,直接调用intentFilter.setPriority();** **如果是静态注册,则是设置intent-fliter的中Priority属性** ![2018120409065645.png][] **优先度的大小设置范围为-1000~1000** ** 想要截断广播,只需要在onreceive()方法中调用aboryBroadcast()即可是广播不再传递下去。** ## **使用本地广播** ## 全局广播,存在有数据安全的问题。 本地广播,只能在本地应用程序中发送与接收广播,可以起到保护数据安全的作用。 回想一下,之前动态注册广播是通过registerReceiver(receiver,intentFilter)这个方法来注册的,其实,本地广播的使用与其十分类似,之前的步骤均是一样的,就是在后面注册调用的方法不同而已,注册时候调用的是LocalBroadcastManager的registerReceiver方法,之前调用的是context的registerReceiver方法,两者参数就是相同的。 ![watermark_type_ZmFuZ3poZW5naGVpdGk_shadow_10_text_aHR0cHM6Ly9ibG9nLmNzZG4ubmV0L3dlaXhpbl80MDc4MzMxNQ_size_16_color_FFFFFF_t_70 4][] **同样的,我们也是需要在onDestory方法中使用localBrocastManager.unregisterReceiver()方法,注意下,图片中我没有把localBroadcastManager定义为全局变量** **发送广播也是类似的** ![20181204091327279.png][] **这里需要说一下,使用本地广播并没有静态注册的方法,因为静态注册主要是为了让程序在未启动的情况下也能收到广播,而发动本地广播的时候,我们的程序已经是启动了,所以,自然是没有静态注册这个方法** ## **常用的action** ## ![watermark_type_ZmFuZ3poZW5naGVpdGk_shadow_10_text_aHR0cHM6Ly9ibG9nLmNzZG4ubmV0L3dlaXhpbl80MDc4MzMxNQ_size_16_color_FFFFFF_t_70 5][] [watermark_type_ZmFuZ3poZW5naGVpdGk_shadow_10_text_aHR0cHM6Ly9ibG9nLmNzZG4ubmV0L3dlaXhpbl80MDc4MzMxNQ_size_16_color_FFFFFF_t_70]: /images/20220412/2d47ade2c280440ba426e14de7f557ef.png [watermark_type_ZmFuZ3poZW5naGVpdGk_shadow_10_text_aHR0cHM6Ly9ibG9nLmNzZG4ubmV0L3dlaXhpbl80MDc4MzMxNQ_size_16_color_FFFFFF_t_70 1]: /images/20220412/3f8e2800e4b64a6ca8c1e52ceef3765c.png [watermark_type_ZmFuZ3poZW5naGVpdGk_shadow_10_text_aHR0cHM6Ly9ibG9nLmNzZG4ubmV0L3dlaXhpbl80MDc4MzMxNQ_size_16_color_FFFFFF_t_70 2]: /images/20220412/d98faa058fc1425886d83bb815db7e48.png [watermark_type_ZmFuZ3poZW5naGVpdGk_shadow_10_text_aHR0cHM6Ly9ibG9nLmNzZG4ubmV0L3dlaXhpbl80MDc4MzMxNQ_size_16_color_FFFFFF_t_70 3]: /images/20220412/1acce30fb1b84f7fa65c5641271c6a12.png [2018120409065645.png]: /images/20220412/ea7c7bfb47574b14b12fad317e2dbffb.png [watermark_type_ZmFuZ3poZW5naGVpdGk_shadow_10_text_aHR0cHM6Ly9ibG9nLmNzZG4ubmV0L3dlaXhpbl80MDc4MzMxNQ_size_16_color_FFFFFF_t_70 4]: /images/20220412/69897095b6014bb38f2f1f45aae44788.png [20181204091327279.png]: /images/20220412/8e2e8a9cb43c4c11bf67f4b6bbecb511.png [watermark_type_ZmFuZ3poZW5naGVpdGk_shadow_10_text_aHR0cHM6Ly9ibG9nLmNzZG4ubmV0L3dlaXhpbl80MDc4MzMxNQ_size_16_color_FFFFFF_t_70 5]: /images/20220412/1cf306706c9845e28b2efbd91e32c5cf.png
还没有评论,来说两句吧...