【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

  • 2017-03-13 12:07:19

    JavaScript原型与原型链分析

    JavaScript没有类的概念,但几乎所有的东西又是基于对象的,同时也能实现继承,这就是js跟其他OOP语言最大的不同之处,这也是js最难理解的一块。下面我来说说我个人的理解。

  • 2017-03-15 07:43:19

    NodeJS服务器”热部署“代码,实现动态调试

    如果你有 PHP 开发经验,会习惯在修改 PHP 脚本后直接刷新浏览器以观察结果,而你在开发 Node.js 实现的 HTTP 应用时会发现,无论你修改了代码的哪一部份,都必须终止Node.js 再重新运行才会奏效。这是因为 Node.js 只有在第一次引用到某部份时才会去解析脚本文件,以后都会直接访问内存,避免重复载入,而 PHP 则总是重新读取并解析脚本(如果没有专门的优化配置)。

  • 2017-03-16 13:37:58

    mysql中如何使用INSERT一次性插入多条记录

    看到这个标题也许大家会问,这有什么好说的,调用多次INSERT语句不就可以插入多条记录了吗!但使用这种方法要增加服务器的负荷,因为,执行每一次 SQL服务器都要同样对SQL进行分析、优化等操作。

  • 2017-03-18 20:17:09

    Linux上vi(vim)编辑器使用教程

    vi(vim)是上Linux非常常用的编辑器,很多Linux发行版都默认安装了vi(vim)。vi(vim)命令繁多但是如果使用灵活之后将会大大提高效率。vi是“visual interface”的缩写,vim是vi IMproved(增强版的vi)。在一般的系统管理维护中vi就够用,如果想使用代码加亮的话可以使用vim。下面vps侦探整理一下vi的使用教程:包含vi的基本介绍、使用模式、文件的打开关闭保存、插入文本或新建行、移动光标、删除、恢复字符或行、搜索等等,算是一篇比较适合新手学习vi的教程。