【Android】BroadCast广播机制应用与实例

2017-03-23 23:57:38

如何编写广播接收器

第一步:需要继承BroadcastReceiver类,覆写其中的onReceive()方法. 

[java] view plain copy

  1. class MyBroadcastReceiver extends BroadcastReceiver {  

  2.      //接收到广播会被自动调用    

  3.     @Override  

  4.     public void onReceive (Context context, Intent intent) {  

  5.         //从Intent中获取action  

  6.         …your code here…  

  7.     }  

  8. }  

第二步:定义好广播接收器还不行,必须向系统注册以便让其知道该接收器可以处理哪些广播事件。

常见方式是采用静态注册,修改MENIFEST.xml文件, 在<application></application>中加入receiver标签.

[html] view plain copy

  1. <application>  

  2.     <activity name=""/>  

  3.     <receiver android:name=".MyBroadcastReceiver">  

  4.         <!-- intent过滤器,指定可以匹配哪些intent, 一般需要定义action 可以是自定义的也可是系统的 -->   

  5.         <intent-filter>  

  6.             <action android:name="com.app.bc.test"/>  

  7.         </intent-filter>  

  8.     </receiver>  

  9. </application>  

第三步:此时我们可以发送一个广播事件出去,代码如下:

[java] view plain copy

  1. Intent intent = new Intent(“com.app.bc.test”);  

  2. sendBroadcast(intent);//发送广播事件  


动态注册广播接收器

在某个Activity中,我们可以用代码来实现动态注册:

[java] view plain copy

  1. //生成一个BroadcastReceiver对象  

  2. SMSReceiver  smsReceiver = new SMSReceiver();  

  3. //生成一个IntentFilter对象  

  4. IntentFilter filter = new IntentFilter();         

  5. filter.addAction(“android.provider.Telephony.SMS_RECEIVED”);  

  6. //将BroadcastReceiver对象注册到系统当中  

  7. //此处表示该接收器会处理短信事件  

  8. TestBC1Activity.this.registerReceiver(smsReceiver, filter);   


静态注册和动态注册的区别

1)静态注册:在AndroidManifest.xml注册,android不能自动销毁广播接收器,也就是说当应用程序关闭后,还是会接收广播。
2)动态注册:在代码中通过registerReceiver()手工注册.当程序关闭时,该接收器也会随之销毁。当然,也可手工调用unregisterReceiver()进行销毁。

操作小结

静态注册的步骤:

定义广播接收器,继承BroadcastReceiver类,覆写onReceive函数.
在xml文件中注册监听器,定义Intent-Filter中感兴趣的action操作.
使用sendBroadCast向系统发送对其感兴趣的广播接收器中.

动态注册的步骤:

[java] view plain copy

  1. SMSReceiver  smsReceiver = new SMSReceiver();  

  2. IntentFilter filter = new IntentFilter();         

  3. filter.addAction(“android.provider.Telephony.SMS_RECEIVED”);  

  4. TestBC1Activity.this.registerReceiver(smsReceiver, filter);   

(无需在配置文件中注册接收器)

应用实例

[java] view plain copy

  1. package com.app.test02;  

  2.   

  3. import android.app.Activity;  

  4. import android.content.Intent;  

  5. import android.content.IntentFilter;  

  6. import android.os.Bundle;  

  7. import android.view.View;  

  8. import android.view.View.OnClickListener;  

  9.   

  10. public class BroadCastActivity1 extends Activity{  

  11.     Intent intent = new Intent();  

  12.     BroadCastTest1 bCastTest1 = new BroadCastTest1();  

  13. //  BroadCastTest11 bCastTest11 = new BroadCastTest11();  

  14. //  BroadCastTest111 bCastTest111 = new BroadCastTest111();  

  15.     @Override  

  16.     protected void onCreate(Bundle savedInstanceState) {  

  17.         // TODO Auto-generated method stub  

  18.         super.onCreate(savedInstanceState);  

  19.           

  20.         setContentView(R.layout.activity_bc1);  

  21.         //静态注册  

  22.         findViewById(R.id.button1).setOnClickListener(new OnClickListener() {  

  23.             @Override  

  24.             public void onClick(View v) {  

  25.                 // TODO Auto-generated method stub  

  26.                 intent.setAction("bc.test101");  

  27.                 intent.putExtra("name""静态的");  

  28.                 sendBroadcast(intent);  

  29. //              sendOrderedBroadcast(intent, null);  

  30.             }  

  31.         });  

  32.         //动态注册  

  33.         findViewById(R.id.button2).setOnClickListener(new OnClickListener() {  

  34.             @Override  

  35.             public void onClick(View v) {  

  36.                 // TODO Auto-generated method stub  

  37.                   

  38.                 IntentFilter intentFilter = new IntentFilter();  

  39.  &nb

  • 2019-08-06 15:30:08

    小程序展示富文本

    然而rich-text有个问题,它不能够给内联img设置宽度100%,这样图片就容易溢出屏幕。我们只能在后台返回富文本的时候对图片的img标签进行格式化。或者前端进行格式化也行,我赞成使用后端,因为很多种情况我们不一定都能想得到。

  • 2019-08-07 09:07:32

    最全的Service Worker讲解

    Service Worker 最主要的特点是:在页面中注册并安装成功后,运行于浏览器后台,不受页面刷新的影响,可以监听和截拦作用域范围内所有页面的 HTTP 请求。 基于 Service Worker API 的特性,结合 Fetch API、Cache API、Push API、postMessage API 和 Notification API,可以在基于浏览器的 web 应用中实现如离线缓存、消息推送、静默更新等 native 应用常见的功能,以给 web 应用提供更好更丰富的使用体验。

  • 2019-08-07 09:09:19

    windows系统下定时关闭程序

    其中xxx.exe是你要关闭的进程中运行的exe,可以ctrl+alt+del打开任务管理器,进到详细信息查看 然后把.txt文件后缀改成.bat(此时要在查看一栏勾上文件拓展名,要不还是txt文档)

  • 2019-08-07 09:16:43

    一个比较完美的PWA例子

    但就目前来讲,PWA是Google主推的一项技术标准,FireFox,Chrome以及一些基于Blink的浏览器已经支持渐进式Web应用了,Edge上对渐进式Web应用的支持还在开发。Apple公司也表示会考虑在自己Safari支持PWA。然而这项功能已经进入了WebKit内核的五年计划中。长期来看,对浏览器兼容性的支持方面应该已经不算太大问题了。况且在现阶段,在不支持渐进式Web应用的浏览器中,你的应用也只是无法使用渐进式Web应用的离线功能而已,除此之外的功能均可以正常使用。

  • 2019-08-07 09:57:48

    spring data jpa 实体类中字段不与数据库表映射

    当我们使用spring data jpa开发的时候,会将实体类中的成员变量与表中的字段一一对应,当我们在实体类中加上一个不与数据库表一一对应的成员变量的时候,此时我们只要在这个成员变量上加上注解@Transient @

  • 2019-08-07 17:16:53

    如何在 Node.js 中使用 import / export 的三种方法

    因为一些历史原因,虽然 Node.js 已经实现了 99% 的 ES6 新特性,不过截止 2018.8.10,How To Enable ES6 Imports in Node.JS 仍然是老大难问题,下面我来介绍三种方法可以让我们在 Node.js 中使用 import/export 。

  • 2019-08-13 08:56:46

    nuxtjs组合element

    添加elementUI 插件,plugins->ele.js,代码如下