broadcastreceiver类怎么读

&&&&&&&&&&&&&&&&&&&&&&&&
&&&&&&&&&&&&&&
&&&&&&&&&&&&&&&&&&&&&&&&& 18:02:17
&&网站联系: qq: email:&4.3.1 BroadcastReceiver牛刀小试 - [ W3School 菜鸟笔记 Android 基础入门教程 ] - 看云
4.3.1 BroadcastReceiver牛刀小试
本节我们将来学习Android四大组件中的第三个:BroadcastReceiver(广播接收者),嘿嘿,刚一直在想 如何写开头语,于是乎翻了手头的两本Android基础书,发现两本书都没有对BroadcastReceiver的介绍, 不知道是巧合还是作者觉得这东西用得不多,没必要讲!不过,他们不讲,小猪却会讲,还要详细讲咧! 好的,开始本节内容~ PS:对了,在Android官网上,点开API Guides -& App Components也没发现有BroadcastReceiver的踪迹, 恩呢,那就直接搜BroadcastReceiver,对应文档地址:
1.BroadcastReceiver是什么鬼?
答:Broadcast直译广播,我们举个形象的例子来帮我理解下BroadcastReceiver,记得以前读书 的时候,每个班级都会有一个挂在墙上的大喇叭,用来广播一些通知,比如,开学要去搬书,广播: "每个班级找几个同学教务处拿书",发出这个广播后,所有同学都会在同一时刻收到这条广播通知, 收到,但不是每个同学都会去搬书,一般去搬书的都是班里的"大力士",这群"大力士"接到这条 广播后就会动身去把书搬回可是!
——好吧,上面这个就是一个广播传递的一个很形象的例子:
大喇叭--& 发送广播 --& 所有学生都能收到广播 --& 大力士处理广播
回到我们的概念,其实BroadcastReceiver就是应用程序间的全局大喇叭,即通信的一个手段, 系统自己在很多时候都会发送广播,比如电量低或者充足,刚启动完,插入耳机,输入法改变等, 发生这些时间,系统都会发送广播,这个叫系统广播,每个APP都会收到,如果你想让你的应用在接收到 这个广播的时候做一些操作,比如:系统开机后,偷偷后台跑服务~哈哈,这个时候你只需要为你的应用 注册一个用于监视开机的BroadcastReceiver,当接收到开机广播就做写偷偷摸摸的勾当~ 当然我们也可以自己发广播,比如:接到服务端推送信息,用户在别处登录,然后应该强制用户下线回到 登陆界面,并提示在别处登录~当然,这些等下都会写一个简单的示例帮大家了解广播给我们带来的好处~
2.两种广播类型:
3.接收系统广播
1)两种注册广播的方式
前面也讲了,系统在某些时候会发送相应的系统广播,下面我们就来让我们的APP接收系统广播, 接收之前,还需要为我们的APP注册广播接收器哦!而注册的方法又分为以下两种:动态与静态!
下面我们分别通过代码来演示两者的用法以及不同之处:
2)动态注册实例(监听网络状态变化)
代码示例:
好的,一开始是没有联网的,即没有打开wifi,点击打开wifi过了一会儿就出现Toast提示了~ 实现起来也很简单!
代码实现:
自定义一个BroadcastReceiver,在onReceive()方法中完成广播要处理的事务,比如这里的提示Toast信息: MyBRReceiver.java
public class MyBRReceiver extends BroadcastReceiver{
public void onReceive(Context context, Intent intent) {
Toast.makeText(context,"网络状态发生改变~",Toast.LENGTH_SHORT).show();
MainActivity.java中动态注册广播:
public class MainActivity extends AppCompatActivity {
MyBRReceiver myR
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
//核心部分代码:
myReceiver = new MyBRReceiver();
IntentFilter itFilter = new IntentFilter();
itFilter.addAction("android.net.conn.CONNECTIVITY_CHANGE");
registerReceiver(myReceiver, itFilter);
//别忘了将广播取消掉哦~
protected void onDestroy() {
super.onDestroy();
unregisterReceiver(myReceiver);
动态注册简单吧~但是动态注册有个缺点就是需要程序启动才可以接收广播,假如我们需要程序 没有启动,但是还是能接收广播的话,那么就需要注册静态广播了!
3)静态注册实例(接收开机广播)
代码示例:
这里就没有示意图了~,直接看代码实现吧~
代码实现:
1.自定义一个BroadcastReceiver,重写onReceive完成事务处理
public class BootCompleteReceiver extends BroadcastReceiver {
private final String ACTION_BOOT = "android.intent.action.BOOT_COMPLETED";
public void onReceive(Context context, Intent intent) {
if (ACTION_BOOT.equals(intent.getAction()))
Toast.makeText(context, "开机完毕~", Toast.LENGTH_LONG).show();
2.在AndroidManifest.xml中对该BroadcastReceiver进行注册,添加开机广播的intent-filter!
对了,别忘了加上android.permission.RECEIVE_BOOT_COMPLETED的权限哦!
&receiver android:name=".BootCompleteReceiver"&
&intent-filter&
&action android:name = "android.intent.cation.BOOT_COMPLETED"&
&/intent-filter&
&/receiver&
&!-- 权限 --&
&uses-permission android:name="android.permission.RECEIVE_BOOT_COMPLETED"/&
好的,然后你重启下手机会发现过了一会儿,就会弹出开机完毕这个Toast的了~ 另外,Android 4.3以上的版本,是允许将程序安装到SD卡上的,假如你的程序是安装在SD上 的,就会收不到开机广播,具体原因以及解决方法下一节再详细讲解!
4)使用广播的注意事项:
嘿嘿,广播好用吧,又简单,但是使用广播要注意:
不要在广播里添加过多逻辑或者进行任何耗时操作,因为在广播中是不允许开辟线程的, 当onReceiver( )方法运行较长时间(超过10秒)还没有结束的话,那么程序会报错(ANR), 广播更多的时候扮演的是一个打开其他组件的角色,比如启动Service,Notification提示, Activity等!
4.发送广播
嗯,上面我们都是接收系统的广播,系统发我们收,我们不能老这么被动,总得主动点是吧! 另外,明天七夕,程序猿们好好把握,争取脱单,哈哈!好的,说回广播,我们自己主动发广播! 下面我们就来看下怎么实现!
如何发送: 发送广播前,要先定义一个接收器,先确定目标,然后再告白!~(●'?'●)~
代码示例:(标准广播)
MyBroadcastReceiver.java
public class MyBroadcastReceiver extends BroadcastReceiver {
private final String ACTION_BOOT = "com.example.broadcasttest.MY_BROADCAST";
public void onReceive(Context context, Intent intent) {
if(ACTION_BOOT.equals(intent.getAction()))
Toast.makeText(context, "收到告白啦~",Toast.LENGTH_SHORT).show();
然后AndroidManifest.xml中注册下,写上Intent-filter:
&receiver android:name=".MyBroadcastReceiver"&
&intent-filter&
&action android:name="com.example.broadcasttest.MY_BROADCAST"/&
&/intent-filter&
&/receiver&
好的,接下来我们把上面这个程序项目运行下,然后关掉,接下来我们新建一个项目, 在这个项目里完成广播发送~新建Demo2,布局就一个简单按钮,然后在MainActivity中完成广播发送:
MainActivity.java:
public class MainActivity extends AppCompatActivity {
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
Button btn_send = (Button) findViewById(R.id.btn_send);
btn_send.setOnClickListener(new View.OnClickListener() {
public void onClick(View v) {
sendBroadcast(new Intent("com.example.broadcasttest.MY_BROADCAST"));
嘿嘿,看下运行截图:
本节小结:
好的,BroadcastReceiver的简单使用就是那么简单,不过我们这里用到的都是全局广播,也就是其他 应用也能收到我们的广播,这样可能会引起一些安全性问题,不过没事,下一节我们来教大家如何用 本地广播,以及Android 4.3后如何应用安装到SD卡上,如何监听开机启动~好的,本节就到这里,谢谢~
页面正在加载中lingdududu 的BLOG
用户名:lingdududu
文章数:217
评论数:189
访问量:1728719
注册日期:
阅读量:24883
阅读量:269458
阅读量:1003041
阅读量:151359
51CTO推荐博文
&一.BroadcastReceiver简介&
&& BraodcastReceiver(广播接收器)是为了实现系统广播而提供的一种组件,它和事件处理机制类似,但是事件处理机制是程序组件级别的,而广播事件处理机制是系统级别的。比如,我们可以发出一种广播来测试手机电量的变化,这时候就可以定义一个BraodcastReceiver来接受广播,当手机电量较低时提示用户。我们既可以用Intent来启动一个组件,也可以用sendBroadcast()方法发起一个系统级别的事件广播来传递消息。我们同样可以在自己的应用程序中实现BroadcastReceiver来监听和响应广播的Intent。
&& 在程序中使用BraodcastReceiver是比较简单的。首先要定义一个类继承BraodcastReceiver,并且覆盖onReceiver()方法来响应事件。然后注册在程序中BraodcastReceiver。最后构建Intent对象调用sendBroadcast()方法将广播发出。
二.BroadcastReceiver的注册方式
&1.静态注册方式
&& 静态注册方式是在AndroidManifest.xml的application里面定义receiver并设置要接收的action。静态注册方式的特点:不管改应用程序是否处于活动状态,都会进行监听,比如某个程序时监听 内存 的使用情况的,当在手机上安装好后,不管改应用程序是处于什么状态,都会执行改监听方法中的内容。
下面是具体的例子:
MainActivity.java
package&com.android. &&import&android.app.A &import&android.content.I &import&android.os.B &import&android.view.V &import&android.view.View.OnClickL &import&android.widget.B &&public&class&MainActivity&extends&Activity{ &&&&&&&&&&protected&static&final&String&ACTION&=&&com.android.broadcast.RECEIVER_ACTION&; &&&&&&&&&&private&Button&btnB &&&&&@Override&&&&&public&void&onCreate(Bundle&savedInstanceState){ &&&&&&&&&super.onCreate(savedInstanceState); &&&&&&&&&setContentView(R.layout.main); &&&&&&&&&btnBroadcast=(Button)findViewById(R.id.btnBroadcast); &&&&&&&&&&&&&&&&&&btnBroadcast.setOnClickListener(new&OnClickListener(){ &&&&&&&&&&&&&@Override&&&&&&&&&&&&&public&void&onClick(View&v){ &&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&Intent&intent=new&Intent(); &&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&intent.setAction(ACTION); &&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&sendBroadcast(intent); &&&&&&&&&&&&&} &&&&&&&&&}); &&&&&} &}&
在&com.android.broadcast&包中定义一个MyReceiver类,继承于BroadcastReceiver,覆盖onReceive()方法。
MyReceiver.java
package&com.android. &&import&android.content.BroadcastR &import&android.content.C &import&android.content.I &import&android.util.L &&public&class&MyReceiver&extends&BroadcastReceiver{ &&&&&&&&&private&static&final&String&TAG&=&&Test&; &&&&&@Override&&&&&public&void&onReceive(Context&context,&Intent&intent){ &&&&&&&&&&&&&&&&&&Log.i(TAG,&&MyReceiver&onReceive---&&); &&&&&} &} &
&version=&1.0&&encoding=&utf-8&&&xmlns:android=&/apk/res/android&&&&&&android:orientation=&vertical&&&&&&android:layout_width=&fill_parent&&&&&&android:layout_height=&fill_parent&&&&&&&&&&&&&&&&&&&&android:id=&@+id/btnBroadcast&&&&&&&&&&android:layout_width=&match_parent&&&&&&&&&&android:layout_height=&wrap_content&&&&&&&&&&android:text=&发送Broadcast&&&&&&&&&&&&
在AndroidManifest.xml配置文件中16~20行声明receiver
&version=&1.0&&encoding=&utf-8&&&xmlns:android=&/apk/res/android&&&&&&&&package=&com.android.broadcast&&&&&&&&android:versionCode=&1&&&&&&&&android:versionName=&1.0&&&&&&&android:minSdkVersion=&10&&&&&&&&&android:icon=&@drawable/icon&&android:label=&@string/app_name&&&&&&&&&&&android:name=&.MainActivity&&&&&&&&&&&&&&&&&&&&android:label=&@string/app_name&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&android:name=&android.intent.action.MAIN&&&&&&&&&&&&&&&&&&&&android:name=&android.intent.category.LAUNCHER&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&android:name=&MyReceiver&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&android:name=&com.android.broadcast.RECEIVER_ACTION&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&
&当我们点击按钮的时候,程序会调用onReceive()方法,LogCat输出信息如下:
&2.动态注册方式
&& 动态注册方式在activity里面调用函数来注册,和静态的内容差不多。一个形参是receiver,另一个是IntentFilter,其中里面是要接收的action。动态注册方式特点:在代码中进行注册后,当应用程序关闭后,就不再进行监听。
下面是具体的例子:
&MainActivity.java
package&com.android. &&import&android.app.A &import&android.content.I &import&android.content.IntentF &import&android.os.B &import&android.view.V &import&android.view.View.OnClickL &import&android.widget.B &&public&class&MainActivity&extends&Activity{ &&&&&&&&&&protected&static&final&String&ACTION&=&&com.android.broadcast.RECEIVER_ACTION&; &&&&&private&Button&btnB &&&&&private&Button&registerR &&&&&private&Button&unregisterR &&&&&private&MyReceiver& &&&&&@Override&&&&&public&void&onCreate(Bundle&savedInstanceState){ &&&&&&&&&super.onCreate(savedInstanceState); &&&&&&&&&setContentView(R.layout.main); &&&&&&&&&btnBroadcast=(Button)findViewById(R.id.btnBroadcast); &&&&&&&&&&&&&&&&&&btnBroadcast.setOnClickListener(new&OnClickListener(){ &&&&&&&&&&&&&@Override&&&&&&&&&&&&&public&void&onClick(View&v){ &&&&&&&&&&&&&&&&&Intent&intent=new&Intent(); &&&&&&&&&&&&&&&&&intent.setAction(ACTION); &&&&&&&&&&&&&&&&&sendBroadcast(intent); &&&&&&&&&&&&&} &&&&&&&&&}); &&&&&&&&& &&&&&&&&&registerReceiver=(Button)findViewById(R.id.btnregisterReceiver); &&&&&&&&&&&&&&&&&&registerReceiver.setOnClickListener(new&OnClickListener(){ &&&&&&&&&&&&&@Override&&&&&&&&&&&&&public&void&onClick(View&v){ &&&&&&&&&&&&&&&&&receiver=new&MyReceiver(); &&&&&&&&&&&&&&&&&IntentFilter&filter=new&IntentFilter(); &&&&&&&&&&&&&&&&&filter.addAction(ACTION); &&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&registerReceiver(receiver,&filter); &&&&&&&&&&&&&} &&&&&&&&&}); &&&&&&&&& &&&&&&&&&unregisterReceiver=(Button)findViewById(R.id.btnunregisterReceiver); &&&&&&&&&&&&&&&&&&unregisterReceiver.setOnClickListener(new&OnClickListener(){ &&&&&&&&&&&&&@Override&&&&&&&&&&&&&public&void&onClick(View&v){ &&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&unregisterReceiver(receiver); &&&&&&&&&&&&&} &&&&&&&&&}); &&&&&} &}&
&在&com.android.broadcast&包中定义一个MyReceiver类,继承于BroadcastReceiver,覆盖onReceive()方法。
MyReceiver.java
package&com.android. &&import&android.content.BroadcastR &import&android.content.C &import&android.content.I &import&android.util.L &&public&class&MyReceiver&extends&BroadcastReceiver{ &&&&&&&&&&private&static&final&String&TAG&=&&Test&; &&&&&@Override&&&&&public&void&onReceive(Context&context,&Intent&intent){ &&&&&&&&&&&&&&&&&&Log.i(TAG,&&MyReceiver&onReceive---&&); &&&&&} &} &
&version=&1.0&&encoding=&utf-8&&&xmlns:android=&/apk/res/android&&&&&&android:orientation=&vertical&&&&&&android:layout_width=&fill_parent&&&&&&android:layout_height=&fill_parent&&&&&&&&&&&&&&&&&&&&android:id=&@+id/btnBroadcast&&&&&&&&&&android:layout_width=&match_parent&&&&&&&&&&android:layout_height=&wrap_content&&&&&&&&&&android:text=&发送广播&&&&&&&&&&&&&&&&&&&&&&&&android:id=&@+id/btnregisterReceiver&&&&&&&&&&android:layout_width=&match_parent&&&&&&&&&&android:layout_height=&wrap_content&&&&&&&&&&android:text=&注册广播接收器&&&&&&&&&&&&&&&&&&&&&&&&android:id=&@+id/btnunregisterReceiver&&&&&&&&&&android:layout_width=&match_parent&&&&&&&&&&android:layout_height=&wrap_content&&&&&&&&&&android:text=&注销广播接听器&&&&&&&&&&&&
①当我们首先点击按钮的时候,因为程序没有注册BraodcastReceiver,所以LogCat没有输出任何信息。
②当我们先点击再点击650) this.width=650;" border="0" alt="" width="71" height="32" src="/attachment/106102.jpg" />按钮的时候,这时程序会动态的注册BraodcastReceiver,之后会调用onReceive()方法,LogCat输出信息如下:
&③当我们点击按钮的时候,这时程序会注销BraodcastReceiver,再点击650) this.width=650;" border="0" alt="" width="71" height="32" src="/attachment/106102.jpg" />,LogCat没有输出任何信息。
三.BroadcastReceiver&的生命周期
&& 一个BroadcastReceiver 对象只有在被调用onReceive(Context, Intent)的才有效的,当从该函数返回后,该对象就无效的了,结束生命周期。
&本文出自 “” 博客,请务必保留此出处
了这篇文章
类别:┆阅读(0)┆评论(0)
本文收录至博客专题:《》Icansoft 的BLOG
用户名:Icansoft
文章数:127
评论数:240
访问量:3378739
注册日期:
阅读量:24883
阅读量:269458
阅读量:1003041
阅读量:151359
51CTO推荐博文
& &BroadcastReceiver 用于异步接收广播Intent。主要有两大类,用于接收广播的:
正常广播 Normal broadcasts(用 Context.sendBroadcast()发送)是完全异步的。它们都运行在一个未定义的顺序,通常是在同一时间。这样会更有效,但意味着receiver不能包含所要使用的结果或中止的API。
&有序广播 Ordered broadcasts(用 Context.sendOrderedBroadcast()发送)每次被发送到一个receiver。所谓有序,就是每个receiver执行后可以传播到下一个receiver,也可以完全中止传播――不传播给其他receiver。 而receiver运行的顺序可以通过matched intent-filter 里面的android:priority来控制,当priority优先级相同的时候,Receiver以任意的顺序运行。
& & 要注意的是,即使是Normal broadcasts,系统在某些情况下可能会恢复到一次传播给一个receiver。 特别是receiver可能需要创建一个进程,为了避免系统超载,只能一次运行一个receiver。& & Broadcast Receiver 并没有提供可视化的界面来显示广播信息。可以使用Notification和Notification Manager来实现可视化的信息的界面,显示广播信息的内容,图标及震动信息。生命周期& & 一个BroadcastReceiver 对象只有在被调用onReceive(Context, Intent)的才有效的,当从该函数返回后,该对象就无效的了,结束生命周期。& & 因此从这个特征可以看出,在所调用的onReceive(Context, Intent)函数里,不能有过于耗时的操作,不能使用线程来执行。对于耗时的操作,请start service来完成。因为当得到其他异步操作所返回的结果时,BroadcastReceiver 可能已经无效了。发送广播& & 事件的广播比较简单,构建Intent对象,可调用sendBroadcast(Intent)方法将广播发出。另外还有sendOrderedBroadcast(),sendStickyBroadcast()等方法,请查阅API Doc。& & 1.new Intent with action name&& & & & Intent intent = new Intent(String action);& & & 或者 只是new Intent, 然后& & & & intent.setAction(String action);& & 2.set data等准备好了后,in activity,& & & &&sendBroadcast(Intent); // 发送广播接收广播& & 通过定义一个继承BroadcastReceiver类来实现,继承该类后覆盖其onReceiver方法,并在该方法中响应事件。public class SMSReceiver extends BroadcastReceiver {
&&&&&&&&@Override
&&&&&&&&public void onReceive(Context context, Intent intent) {&&&&&&&&&&&&&&&&&// get data from SMS intent
&&&&&&&&&&&&&&&&Bundle bundle = intent.getExtras();
&&&&&&&&&&&&&&&&if (bundle != null){
&&&&&&&&&&&&&&&&&&&&&&&&// get message by "pdus"
&&&&&&&&&&&&&&&&&&&&&&&&Object[] objArray = (Object[]) bundle.get("pdus");
&&&&&&&&&&&&&&&&&&&&&&&&// rebuild SMS
&&&&&&&&&&&&&&&&&&&&&&&&SmsMessage[] messages = new SmsMessage[objArray.length];
&&&&&&&&&&&&&&&&&&&&&&&&for (int i=0; i & objArray. i++){
&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&messages[i] = SmsMessage.createFromPdu((byte[])objArray[i]);
&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&StringBuilder str = new StringBuilder("from: ");
&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&str.append(messages[i].getDisplayOriginatingAddress());
&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&str.append("\nmessage:\n");
&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&str.append(messages[i].getDisplayMessageBody());
&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&Toast.makeText(context, str.toString(), Toast.LENGTH_LONG)
&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&.show();
&&&&&&&&&&&&&&&&&&&&&&&&}
&&&&&&&&&&&&&&&&}
}注册Receiver& &注册有两种方式:& &1. 静态方式,在AndroidManifest.xml的application里面定义receiver并设置要接收的action。&receiver android:name=".SMSReceiver"&
&&&&&&&&&intent-filter&
&&&&&&&&&&&&&&&&&action android:name="android.provider.Telephony.SMS_RECEIVED" /&
&&&&&&&&&/intent-filter&
&/receiver&& &2. 动态方式, 在activity里面调用函数来注册,和静态的内容差不多。一个形参是receiver,另一个是IntentFilter,其中里面是要接收的action。public class HelloDemo extends Activity {&&&&&&&&&&&&private BroadcastR&&&&
&&&&&&&&@Override
&&&&&&&&protected void onStart() {
&&&&&&&&&&&&&&&&super.onStart();
&&&&&&&&&&&&&&&&receiver = new CallReceiver();
&&&&&&&&&&&&&&&&registerReceiver(receiver, new IntentFilter("android.intent.action.PHONE_STATE"));
&&&&&&&&@Override
&&&&&&&&protected void onStop() {
&&&&&&&&&&&&&&&&unregisterReceiver(receiver);
&&&&&&&&&&&&&&&&super.onStop();
}& &一个receiver可以接收多个action的,即可以有多个intent-filter,需要在onReceive里面对intent.getAction(action name)进行判断。&& & 个人推荐使用静态注册方式,由系统来管理receiver,而且程序里的所有receiver,可以在xml里面一目了然。而动态注册方式,隐藏在代码中,比较难发现。&
& 而且动态注册,需要特别注意的是,在退出程序前要记得调用Context.unregisterReceiver()方法。一般在activity的onStart()里面进行注册, onStop()里面进行注销。官方提醒,如果在Activity.onResume()里面注册了,就必须在Activity.onPause()注销。Permission权限&
要接收某些action,需要在AndroidManifest.xml里面添加相应的permission。例如接收SMS:&uses-permission android:name="android.permission.RECEIVE_SMS" /&
下面给出动态注册的接收来电的广播处理的CallReceiver的代码:& &一种方式是直接读取intent.getStringExtra("incoming_number")来获取来电号码:public class CallReceiver extends BroadcastReceiver {
&&&&&&&&@Override
&&&&&&&&public void onReceive(Context context, Intent intent) {
&&&&&&&&&&&&&&&&TelephonyManager teleManager = (TelephonyManager) context.getSystemService(Context.TELEPHONY_SERVICE);
&&&&&&&&&&&&&&&&
&&&&&&&&&&&&&&&&switch(teleManager.getCallState()){
&&&&&&&&&&&&&&&&case TelephonyManager.CALL_STATE_RINGING: //响铃
&&&&&&&&&&&&&&&&&&&&&&&&Toast.makeText(context, "Ringing: " + intent.getStringExtra("incoming_number"), Toast.LENGTH_LONG).show();
&&&&&&&&&&&&&&&&&&&&&&&&break;
&&&&&&&&&&&&&&&&case TelephonyManager.CALL_STATE_OFFHOOK: //接听
&&&&&&&&&&&&&&&&&&&&&&&&Toast.makeText(context, "OffHook: " + intent.getStringExtra("incoming_number"), Toast.LENGTH_LONG).show();
&&&&&&&&&&&&&&&&&&&&&&&&break;
&&&&&&&&&&&&&&&&case TelephonyManager.CALL_STATE_IDLE: //挂断
&&&&&&&&&&&&&&&&&&&&&&&&Toast.makeText(m_context, "Idle: " + incomingNumber, Toast.LENGTH_LONG).show();
&&&&&&&&&&&&&&&&&&&&&&&&break;
&&&&&&&&&&&&&&&&}
}& &在运行时,发现除了响铃时可以获取来电号码,接听和挂断都不能成功获取的,显示为null。& &另一种方式是通过PhoneStateListener的onCallStateChanged来监听状态的变化:public class CallReceiver extends BroadcastReceiver {
&&&&&&&&private Context m_
&&&&&&&&@Override
&&&&&&&&public void onReceive(Context context, Intent intent) {
&&&&&&&&&&&&&&&&m_context =
&&&&&&&&&&&&&&&&TelephonyManager teleManager = (TelephonyManager) context.getSystemService(Context.TELEPHONY_SERVICE);
&&&&&&&&&&&&&&&&teleManager.listen(new PhoneStateListener(){
&&&&&&&&&&&&&&&&&&&&&&&&@Override
&&&&&&&&&&&&&&&&&&&&&&&&public void onCallStateChanged(int state, String incomingNumber) {
&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&switch(state){
&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&case TelephonyManager.CALL_STATE_RINGING: //响铃
&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&Toast.makeText(m_context, "Ringing: " + incomingNumber, Toast.LENGTH_LONG)
&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&.show();
&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&break;
&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&case TelephonyManager.CALL_STATE_OFFHOOK: //接听
&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&Toast.makeText(m_context, "OffHook: " + incomingNumber, Toast.LENGTH_LONG)
&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&.show();
&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&break;
&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&case TelephonyManager.CALL_STATE_IDLE: //挂断
&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&Toast.makeText(m_context, "Idle: " + incomingNumber, Toast.LENGTH_LONG)
&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&.show();
&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&break;
&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&}
& & & & & & & & & & & & }}, PhoneStateListener.LISTEN_CALL_STATE);
&&&&&&&&&}
}& & 运行时也发现incomingNumber在接听和挂断时获取为blank。& & 因为这里监听的是通话的状态变化,所以这个receiver会被调用3次。& & 监听通话状态需要加上权限:&uses-permission android:name="android.permission.READ_PHONE_STATE"/&===========小结:1. 对于sendBroadCast的intent对象,需要设置其action name;&2. 推荐使用显式指明receiver,在配置文件AndroidManifest.xml指明;&3. 一个receiver可以接收多个&4. 每次接收广播都会重新生成一个接收广播的对象,再次调用onReceive;5. 在BroadCast 中尽量不要处理太多逻辑问题,建议复杂的逻辑交给Activity 或者 Service 去处理。
了这篇文章
类别:┆阅读(0)┆评论(0)
13:20:21 12:30:18 15:58:24 17:14:28

我要回帖

更多关于 broadcastreceiver ui 的文章

 

随机推荐