【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-12-14 21:04:05

    聊聊keep-alive组件的使用及其实现原理

    keep-alive是Vue.js的一个内置组件。它能够不活动的组件实例保存在内存中,而不是直接将其销毁,它是一个抽象组件,不会被渲染到真实DOM中,也不会出现在父组件链中。 它提供了include与exclude两个属性,允许组件有条件地进行缓存。

  • 2019-12-14 21:06:58

    vue----keep-alive缓存,activated,deactivated两个生命周期函数,,meta实现缓存

    如果没有缓存,每点击一次导航,内容区就会创建一个组件,该组件会经历整个生命周期,每点击一次,就会创建一个组件,比较浪费性能, 这时,我们就要考虑到是否能将点击过的已创建的组件进行缓存,当再次点击已访问过的组件时,这时,就会从缓存中获取该组件,而不会重新创建,

  • 2019-12-17 11:56:05

    ffmpeg concat video and mix audio,ffmpeg简单快速的合并视频

    在ffmpeg中,官网给出两种连接媒体文件(音频、视频、etc..)的解决方案。 the concat "demuxer" the concat "protocol" 对比而言, demuxer更加灵活一些,需要媒体文件是属于相同的编解码器,但是可以属于不同的容器格式(mp3,wav, mp4, mov, etc..). 而protocol只适用于少数集中容器格式。

  • 2019-12-17 11:58:55

    FFmpeg文章目录

    seek ffmpeg # How to seek in mp4/mkv/ts/flv ffmpeg # flags &= ~AVSEEK_FLAG_BACKWARD ffmpeg # AVSEEK_FLAG concat ffmpeg # concat 连接两个视频 ffmpeg # -f concat -i mylist.txt ffmpeg # concat详解+音画同步策略 截图