BroadcastReceive基础知识总结「建议收藏」

BroadcastReceive基础知识总结「建议收藏」1、普通广播2、有序广播3、粘性广播4、电量、开机广播

大家好,又见面了,我是你们的朋友全栈君。

BroadcastReceive基础知识总结

1、BroadcastReceive简介

  • BroadcastReceive也就是“广播接收者”的意思,顾名思义,就是用来接收来自系统和应用中的广播
  • 在Android系统中,广播体现在方方面面,例如当开机完成后系统会产生一条广播,接收到这条广播就能实现开机启动服务的功能,当网络状态改变时,系统会产生一条广播,接收到这条广播,就能及时的做出提示和保存数据等操作,当电池的电量改变的时候,系统会产生一条广播,接收到这条广播就能在电量低的时候告知用户,及时保存进度。等等
  • Android中的广播机制设计的非常出色,很多事情原本需要开发者亲自操作的额,现在只需要广播告知自己就可以了,大大的减少了开发的工作量和开发周期,而作为应用开发者,就需要熟练掌握Android系统提供的一个开发利器,那就是BroadcastReceive。

2、广播接收器的类型

  • (1)Normal broadcasts:默认广播
    • 发送一条默认的广播 Context.sendBroadcast()方法,普通广播对于多个接收者来说是异步的,通常每个接受者都无需等待即可以接收到广播,接受者相互之间不会有影响,对于这种广播,接受者无法终止广播,即无法阻止其他接受者的接收动作
    • MainActivity.java
        sendNormal = (Button) findViewById(R.id.sendNormal);
        sendNormal.setOnClickListener(new OnClickListener());


    /** * 自定义的内部click */
    class OnClickListener implements View.OnClickListener { 
   

        @Override
        public void onClick(View v) {
            switch (v.getId()) {
                case R.id.sendNormal:
                    Intent intent = new Intent("com.wuyinlei.action.BROADCAST");
                    intent.putExtra("info","我们很有缘,谢谢你收到我");
                    MainActivity.this.sendBroadcast(intent);
                    break;
            }
        }
    }

MyReceiver.java


/** * 自定义的广播接收器 */
public class MyReceiver extends BroadcastReceiver { 
   
    public MyReceiver() {
    }

    /** * 接受的方法 * @param context * @param intent */
    @Override
    public void onReceive(Context context, Intent intent) {
        String info = intent.getStringExtra("info");
        Toast.makeText(context, info, Toast.LENGTH_SHORT).show();
    }
}

mainfest.xml

 <receiver  android:name=".MyReceiver" android:enabled="true" android:exported="true">
            <intent-filter>
                <action android:name="com.wuyinlei.action.BROADCAST"></action>
            </intent-filter>
        </receiver>
  • (2)Ordered broadcasts:有序广播
    • 发送一个有序广播使用Context.sendOrderedBroadcast()方法,有序广播比较特殊,它每次只发死你个到优先级较高的接受者那里,然后由优先级高的接受者在传播到优先级别低的接受者那里,优先级高的接受者又能力终止这个广播
  • (3)Sticky Broadcast:粘性广播
    • 当处理完之后的Intent,依然存在,知道你把它去掉

3、广播接收器的创建步骤

  • 1、构建Intent,使用sendBroadcast方法发送广播
  • 2、定义一个广播接收器,该广播接收器集成BroadcastReceiver,并且覆盖onReceive()方法来响应事件
  • 3、注册广播接收器,我们可以在代码中注册,也可以在AndroidManifest.xml配置文件中注册

4、注册广播接收器的两种方式

  • 静态注册

    • 静态注册是在AndroidManifest.xml文件中配置

                 <receiver  android:name=".MyReceiver" android:enabled="true" android:exported="true">
            <intent-filter>
                <action android:name="com.yinlei.action.MY_BROADCAST"></action>
            </intent-filter>
        </receiver>
            这个时候,我们需要在Activity或者Service中这样
    
             Intent intent = new Intent("com.yinlei.action.MY_BROADCAST");
                            intent.putExtra("info","我是自定义广播");
                            sendBroadcast(intent);
  • 动态注册
    • 动态注册需要在代码中动态的指定广播地址并注册,通常我们是在Activity或者Service注册一个广播
                MyReceiver receiver = new MyReceiver();
                IntentFilter filter = new IntentFilter();
                filter.addAction("android.intent.action.MY_BROADCAST");
                registerReceiver(receiver,filter);

                解除注册
                unregisterReceiver(receiver);
  • 注意:
    • 在这个方法中发来的广播中,代码注册方式中,接收到的广播的先后和注明优先级最高的他们的先后是随机的,如果没有优先级,代码注册收到为最先

5、有序广播

  • 发送广播
sendOrderedBroadcast();
* 在注册广播中的<intent-filter>中使用android:priority属性,这个属性的范围在-1000---1000。
* 数值越大,优先权越高,在广播接收者中使用setResultExtras方法将一个Bundle对象设置为结果集对象,传递到下一个接受者哪里,这样优先级低的接受者可以用getResultExtras获取到最新的经过处理的信息集合
* 使用sendOrderedBroadcast方法有序广播的时候,需要一个权限参数,如果为null则表示不要求接收者声明指定的权限,如果不为null,则表示接收者要接收此广播,需声明指定权限,这样做是从安全角度考虑的,例如系统的短信就是有序的广播的形式,一个应用可能是具有拦截垃圾短信的功能,当短信到来的时候它可以先接收到短信,必要时候终止广播的传递,这样的软件就必须声明接收短信的权限。
  • 终止广播传递
abortBroadcast()
 * 同级别接收是先后是随机的,在到级别低的收到广播,如果先接收到的把广播拦截了,同级别以外的接收者是无法收到该广播的
 * 在这个方法发来的广播(代码注册方式中),收到广播先后次序为:注明优先级的、代码优先级的、没有优先级的,如果都没有优先级,代码注册接收到优先
  • 创建的两个有序广播
case R.id.sendOrder:
                    Intent intentOrder = new Intent("com.wuyinlei.action.MY_BROADCAST");

                    //第一个参数是intent,第二个是接收的权限
                    MainActivity.this.sendOrderedBroadcast(intentOrder,null);
                    break;

mainfest.xml配置

 <receiver  android:name=".ThreeReceiver" android:enabled="true" android:exported="true" >
            <intent-filter android:priority="100">
                <action android:name="com.wuyinlei.action.MY_BROADCAST"></action>
            </intent-filter>
        </receiver>
        <receiver  android:name=".FourReceiver" android:enabled="true" android:exported="true">
            <intent-filter android:priority="200">
                <action android:name="com.wuyinlei.action.MY_BROADCAST"></action>
            </intent-filter>
        </receiver>

有序广播的gif图:
这里写图片描述
有序广播传值gif图:
这里写图片描述

6、粘性广播

  • 发送粘性广播使用:sendStickBroadcast(intent)
  • 发送这个广播需要权限
 <uses-permission android:name="android.permission.BROADCAST_STICKY"/>
  • 去掉这个removeStickyBroadcast(intent)
  • sendStickyOrderedBroadcast():这个方法具有有序广播的特性也有粘性广播的特性;
    • 在这个方法发来的广播中,代码注册方式中,收到广播先后次序为:注明优先级的、代码注册的、没有优先级的;如果都没有优先级,代码注册的收到最先。
      MainActivity.java
                case R.id.sendSticky:
                    Intent intentSticky = new Intent("com.wuyinlei.action.MY_BROADCAST_STICKY");
                    MainActivity.this.sendStickyBroadcast(intentSticky);
                    break;

                case R.id.startSticky:
                    startActivity(new Intent(MainActivity.this, ReceiveActivity.class));
                    break;

ReceiveActivity.java

 @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_receive);
        mFiveReceiver = new FiveReceiver();
    }

    @Override
    protected void onResume() {
        super.onResume();
        IntentFilter filter = new IntentFilter();
        filter.addAction("com.wuyinlei.action.MY_BROADCAST_STICKY");
        registerReceiver(mFiveReceiver,filter);
    }

    @Override
    protected void onPause() {
        super.onPause();
        unregisterReceiver(mFiveReceiver);
    }

粘性广播GIF图:
这里写图片描述
###7、接收系统广播
* 1、开机启动广播
* 我们经常会有这样的应用场合,比如消息推送服务,需要实现开机启动的功能,要实现这个功能,我们就可以订阅系统“启动完成”这条广播,接收到这条广播,我们就可以启动自己的服务了

              <intent-filter>
                    <!--注册开机广播地址-->
                    <action android:name="android.intent.action.BOOT_COMPLETED"/>
                    <category android:name="android.intent.category.DEFAULT"/>
                </intent-filter>

这个开机广播地址,从安全角度考虑,系统要求必须声明接收开机启动广播的权限。

            <user-permission android:name="android.peimission.RECEIVE_BOOT_COMPLETE"/>
* 2、网络状态变化
   * 比如用户游览游览器信息的时候,网络突然断开,我们要及时的提醒用户网络已经断开,要实现这个功能,我们可以接受网络状态改变这样的一条广播,当由连接状态变为断开状态时候,系统就会收到一条广播,我们接收到之后,在通过网络的状态做出相应的操作
         <intent-filter>
                <action android:name="android.net.conn.CONNECTIVITY_CHANGE"/>
                <category android:name="android.intent.category.DEFAULT"/>
            </intent-filter>
访问的网络状态权限:
 <user-permission android:name="android.peimission.ACCESS_NETWORK_STATE"/>

 ConnectivityManager cm = (ConnectivityManager) context.getSystemService(Context.CONNECTIVITY_SERVICE);
    NetworkInfo info = cm.getActiveNetworkInfo();
    String typeName = info.getTypeName();//连接类型
    info.getState();//连接状态
* 3、电量变化
   * 如果我们在使用阅读软件,可能全屏阅读,这个时候用户就看不到剩余的电量了,我们就可以为他们提供电量的信息,要想做到这一点,我们需要接受一条电量变化的广播,然后获取百分比信息
   * int currLevel = intent.getIntExtra(BatteryManager.EXTRA_LEVEL,0)  //当前电量
   * int total = intent.getIntExtra(BatteryManager.EXTRA_SCALE,1)//总电量
   * int percent = currLevel*100/total;
              <intent-filter>
            <action android:name="android.intent.action.BATTERY_CHANGED"/>
            <category android:name="android.intent.category.DEFAULT"/>
                            </intent-filter>
   立即获取电量,而不是等电量变化的广播,可以使用:
       Intent batteryIntent = getApplicationContext().registerReceiver(null,new IntentFilter(Intent.ACTION_BATTERY_CHANGED))

“`
这里附上github地址:https://github.com/wuyinlei/Broadcast

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/151235.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • Vue中 使用定时器 (setInterval、setTimeout)[通俗易懂]

    Vue中 使用定时器 (setInterval、setTimeout)[通俗易懂]js中定时器有两种,一个是循环执行setInterval,另一个是定时执行setTimeout。定时器需要在页面销毁的时候清除掉,不然会一直存在!1.循环执行(setInterval)顾名思义,循环执行就是设置一个时间间隔,每过一段时间都会循环执行这个方法,直到这个定时器被销毁掉;语法:setInterval(code,milliseconds);setInterval(function,milliseconds,param1,param2,…);code/funct

    2022年9月28日
    1
  • Django外键(ForeignKey)操作以及related_name的作用

    Django外键(ForeignKey)操作以及related_name的作用之前已经写过一篇关于Django外键的文章,但是当时并没有介绍如何根据外键对数据的操作,也就是如何通过主表查询子表或者通过子表查询主表的信息  首先我定义了两个模型,一个是老师模型,一个是学生模型,一个老师对应多个学生,这个算是一个一对多的类型(如下图所示)      那么如果我们要想查询一个老师对应的学生有哪些,该如何操作呢?   首先我们先查询到老师的信息,在这里我们使用pyt

    2022年6月23日
    28
  • windows多线程(一) 创建线程 CreateThread「建议收藏」

    windows多线程(一) 创建线程 CreateThread「建议收藏」一线程创建函数CreateThread修改说明:"这里"说了另一种创建线程方法,使用_beginthreadex()更安全的创建线程,在实际使用中尽量使用_beginth

    2022年7月4日
    88
  • insert into select * from 锁表

    insert into select * from 锁表mysql[192.168.11.187]processid[249]root@localhostindb[zjzc]holdtransactiontime197112069858,

    2022年7月2日
    23
  • 基于51单片机的红绿灯设计

    基于51单片机的红绿灯设计寒假项目最后一个,基于STC/AT89C51的红路灯设计实现十效果具体为:南北通行42秒,南北闪烁3秒,南北黄灯4秒,禁止通行1秒,东西黄灯4秒,东西通行27秒,东西闪烁3秒,东西黄灯4秒。同时具备特殊放行模式:南北自由通行;东西自由通行;全部禁行。所有时间可以修改。貌似和平时的红路灯不一样,但是由于想凑齐八个状态,就整了这神奇的控制步骤。黄灯多,安全第一!!原理图:本来是想设计一个蓝牙或者……

    2025年5月24日
    7
  • 图解Kafka的服务端的网络通信模型

    图解Kafka的服务端的网络通信模型在开始讲解Kafka的网络通信模型之前,我们有必要先简单了解一下:线程模型Reactor模式Reactor模式Reactor模式,是指通过一个或多个输入同时传递给服务处理器的服务请求的事件驱动处理模式。服务端程序处理传入多路请求,并将它们同步分派给请求对应的处理线程,Reactor模式也叫Dispatcher模式。即I/O多了复用统一监听事件,收到事件后分发(Dispatch给某进程),是编写高性能网络服务器的必备技术之一。根据Reactor的数量和处理资源池线程的数量不同,有

    2022年7月14日
    18

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号