【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-28 08:49:47

    Nginx + fastcgi + php 的原理与关系

    CGI对每个请求会parse一遍对应脚本的配置文件(如php.ini), 加载配置和扩展,初始化执行环境,性能非常差,所有有了下面的流程:

  • 2019-08-28 09:23:15

    php单例模式

    单例模式,是一种常见的软件设计模式。在应用这个模式时,单例对象的类必须保证只有一个实例存在。

  • 2019-08-28 22:45:02

    彻底搞懂Gradle、Gradle Wrapper与Android Plugin for Gradle的区别和联系

    Gradle是个构建系统,能够简化你的编译、打包、测试过程。熟悉Java的同学,可以把Gradle类比成Maven。Gradle Wrapper的作用是简化Gradle本身的安装、部署。不同版本的项目可能需要不同版本的Gradle,手工部署的话比较麻烦,而且可能产生冲突,所以需要Gradle Wrapper帮你搞定这些事情。Gradle Wrapper是Gradle项目的一部分。

  • 2019-08-30 21:53:51

    OpenSSL实践-Android下的编译和使用

    openssl可以编译成ARM下面的二进制代码(动态库或者静态库),方便APP使用,APP在使用的时候,需要使用JNI来进行调用。

  • 2019-08-31 14:05:00

    JNI Crash:异常定位与捕获处理

    在Android JNI开发中,经常会遇到JNI崩溃的问题,尤其带代码量大,或者嵌入了第三方代码的情况下,很难进行问题定位和处理。本文将介绍两种常见的JNI崩溃处理方法,包括: 每个JNI调用后进行异常检测处理(适用于JNI代码量很小的情况) 捕获系统崩溃的Signal,并进行异常处理(适用于JNI代码量大,难以每句话后面都进行异常检测的情况)