zoukankan      html  css  js  c++  java
  • 广播接收者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;
    
    //发出此广播的地方frameworksaseservicesjavacomandroidserverDockObserver.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(); 可以拦截广播,不继续传播。

      四,自定义本地广播(不能静态注册)

    基本上就和的动态注册广播接收器以及发送广播的代码是一样。只不过现在

      首先是通过 LocalBroadcastManagergetInstance()方法得到了它的一个实例,
      然后在注册广播接收器的时候调用的是 LocalBroadcastManagerregisterReceiver()方法,
      在发送广播的时候调用的是 LocalBroadcastManager sendBroadcast()方法,
      取消注册调用的是localBroadcastManager的unregisterReceiver方法

    仅此而已。这里我们在按钮的点击事件里面发出了一条自己的广播,然后在 LocalReceiver 里去接收这条广播。 

    岑忠满的博客新站点 https://cenzm.xyz
  • 相关阅读:
    cloudemanager安装时出现8475 MainThread agent ERROR Heartbeating to 192.168.30.1:7182 failed问题解决方法(图文详解)
    cloudemanager安装时出现ProtocolError: <ProtocolError for 127.0.0.1/RPC2: 401 Unauthorized>问题解决方法(图文详解)
    青年的第一要务是自立
    [转]Sql Server 主从数据库配置
    [转]SQL Server表分区
    [转]WCF体系结构-一张图就是好
    Bootstrap
    [转]在WIN7下安装运行mongodb
    [转]使用Node.js完成的第一个项目的实践总结
    [转]win系统下nodejs安装及环境配置
  • 原文地址:https://www.cnblogs.com/cenzhongman/p/6048110.html
Copyright © 2011-2022 走看看