Android 四大组件学习之BroadcastReceiver三
本节学习广播的分类。
广播分为无序广播和有序广播
无序广播:
广播发送者的action与广播接收者的action都匹配的话,所以广播介绍者都能够收到这条广播,而且没有先后顺序,能够觉得是同一时候收到
有序广播:
广播发送者的action与广播接收者的action都匹配的话,所以广播介绍者都能够收到这条广播,可是有先后顺序,高优先级的先收到
既然知道什么是无序广播和有序广播后, 那我们举例说明:
那我们模拟生活中一个样例说明。 某高校正在举行体操比赛。
这时候我们伟大的计算机学院就开会了。
院长将几个班级的导员开会完,导员又组织各个班的班长开会,最后各个班级的班长给大家传达会议精神。
我们如果: 某某某高校校长是这次广播的发送者。计算机学院的院长。导员和各个班的班长是广播接收者
先用无序广播举例:
第一: 创建校长应用程序。也就是广播的发送者:
public class PresidentActivity extends Activity {
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
}
public void sendBroadcast(View v)
{
Intent intent = new Intent();
intent.setAction("com.demo.SPORT_MEET_SPIRIT");
intent.putExtra("SPORT_MEET", "每一个学生早上7点必须上早操");
sendBroadcast(intent);
}
}
第二: 创建计算机学校院长接收者。也就是广播的接收者
public class ComputerPresidentReceiver extends BroadcastReceiver {
@Override
public void onReceive(Context context, Intent intent) {
// TODO Auto-generated method stub
String spirit = intent.getExtras().getString("SPORT_MEET");
Log.i("TeacherReceiver", "校长说: "+spirit);
}
}
第三:创建导员接收者,也就是广播的介绍者
public class TeacherReceiver extends BroadcastReceiver {
@Override
public void onReceive(Context context, Intent intent) {
String spirit = intent.getExtras().getString("SPORT_MEET");
Log.i("TeacherReceiver", "院长说: "+spirit);
}
}
第三:创建最不听话的计算机同学接收者。也就是广播的接收者:
public class StudentReceiver extends BroadcastReceiver {
@Override
public void onReceive(Context context, Intent intent) {
// TODO Auto-generated method stub
//得到广播的数据
String spirit = intent.getExtras().getString("SPORT_MEET");
//显示
Log.i("StudentReceiver", "导员说: "+spirit);
}
}
此时清单文件里配置为:
<receiver android:name="com.demo.broadcastreceiveractivity.ComputerPresidentReceiver">
<intent-filter >
<action android:name="com.demo.SPORT_MEET_SPIRIT"></action>
</intent-filter>
</receiver>
<receiver android:name="com.demo.broadcastreceiveractivity.TeacherReceiver">
<intent-filter >
<action android:name="com.demo.SPORT_MEET_SPIRIT"></action>
</intent-filter>
</receiver>
<receiver android:name="com.demo.broadcastreceiveractivity.StudentReceiver">
<intent-filter >
<action android:name="com.demo.SPORT_MEET_SPIRIT"></action>
</intent-filter>
</receiver>
ok。当我们校长发送广播后:看看现象:
能够看到先是校长说。然后院长说,再然后是导员说。
看起来好像挺有顺序的。可是我将配置文件的顺序改为:
<receiver android:name="com.demo.broadcastreceiveractivity.StudentReceiver">
<intent-filter >
<action android:name="com.demo.SPORT_MEET_SPIRIT"></action>
</intent-filter>
</receiver>
<receiver android:name="com.demo.broadcastreceiveractivity.TeacherReceiver">
<intent-filter >
<action android:name="com.demo.SPORT_MEET_SPIRIT"></action>
</intent-filter>
</receiver>
<receiver android:name="com.demo.broadcastreceiveractivity.ComputerPresidentReceiver">
<intent-filter >
<action android:name="com.demo.SPORT_MEET_SPIRIT"></action>
</intent-filter>
</receiver>
学生放在最前面注冊,则结果为:
watermark/2/text/aHR0cDovL2Jsb2cuY3Nkbi5uZXQv/font/5a6L5L2T/fontsize/400/fill/I0JBQkFCMA==/dissolve/70/gravity/Center" alt="">
这时候顺序明显不正确了。 这就是无序广播的特点。对于接受没有先后顺序。这明显和实际不符合。要想做到符合就必须用有序广播
举例有序广播:
首先: 给每一个广播接受者设置权限,权限是-1000到1000。当中1000的优先级最高
<receiver android:name="com.demo.broadcastreceiveractivity.StudentReceiver">
<intent-filter android:priority="500">
<action android:name="com.demo.SPORT_MEET_SPIRIT"></action>
</intent-filter>
</receiver>
<receiver android:name="com.demo.broadcastreceiveractivity.TeacherReceiver">
<intent-filter android:priority="800">
<action android:name="com.demo.SPORT_MEET_SPIRIT"></action>
</intent-filter>
</receiver>
<receiver android:name="com.demo.broadcastreceiveractivity.ComputerPresidentReceiver">
<intent-filter android:priority="1000">
<action android:name="com.demo.SPORT_MEET_SPIRIT"></action>
</intent-filter>
</receiver>
其次: 发送广播的方式就的改变:
public void sendBroadcast(View v)
{
Intent intent = new Intent();
intent.setAction("com.demo.SPORT_MEET_SPIRIT");
//intent.putExtra("SPORT_MEET", "每一个学生早上7点必须上早操"); //发送的广播为无序广播
//sendBroadcast(intent); //发送有序广播
sendOrderedBroadcast(intent, null, null, null, 0, "每一个学生早上7点必须上早操", null);
}
然后。就每一个接收者做个调整:
计算机院长把校长的话给改了,校长说计算机要当第一必须6点半起来:
public class ComputerPresidentReceiver extends BroadcastReceiver {
@Override
public void onReceive(Context context, Intent intent) {
// TODO Auto-generated method stub
//假设发送的时候数据是通过intent发送的,就通过intent取得
//String spirit = intent.getExtras().getString("SPORT_MEET");
//假设不是。就是简单的字符串的话,能够通过getResultData得到
String spirit = getResultData();
Log.i("ComputerPresidentReceiver", "校长说: "+spirit);
setResultData("每一个学生早上6点半必须上早操");
}
}
这时候广播到导员了。导员说计算机系必须当第一。6点起来:
public class TeacherReceiver extends BroadcastReceiver {
@Override
public void onReceive(Context context, Intent intent) {
// TODO Auto-generated method stub
//String spirit = intent.getExtras().getString("SPORT_MEET");
String spirit = getResultData();
Log.i("TeacherReceiver", "院长说: "+spirit);
setResultData("每一个学生早上6点必须上早操");
}
}
这时候班长传达旨意来了:
public class StudentReceiver extends BroadcastReceiver {
@Override
public void onReceive(Context context, Intent intent) {
// TODO Auto-generated method stub
//得到广播的数据
//String spirit = intent.getExtras().getString("SPORT_MEET");
//显示
String spirit = getResultData();
Log.i("StudentReceiver", "导员说: "+spirit);
setResultData("谁爱上谁上去,反正我不去!");
}
}
这时候同学们就说: 谁爱上谁上去,反正我不去!
看一下执行效果:
这样校长的旨意就传达了。可是同学们究竟该怎么办呢? 有一天学校的检查部门(也就是一帮臭b学生会,来检查上早操的人数)
这时候我们就须要对发送者在改造:
public void sendBroadcast(View v)
{
Intent intent = new Intent();
intent.setAction("com.demo.SPORT_MEET_SPIRIT");
//intent.putExtra("SPORT_MEET", "每一个学生早上7点必须上早操"); //发送的广播为无序广播
//sendBroadcast(intent); //发送有序广播
sendOrderedBroadcast(intent, null, new resultReceiver(), null, 0, "每一个学生早上7点必须上早操", null);
} //广播的终于接受者
class resultReceiver extends BroadcastReceiver
{ @Override
public void onReceive(Context context, Intent intent) {
// TODO Auto-generated method stub
String spirit = getResultData();
Log.i("resultReceiver", "计算机上早情况:" + spirit);
} }
演示效果为:
学生会一看,计算机系8点了还没人上早操,就几个胆小的去上了。
这就是有序广播,发送者发送后,第一个接受者能够对广播的内容改动,同一时候也能够终止广播的继续发送。
可是广播的终于接受者是一定能够收到此广播的。
比方: 有一天导员比較忙,忘记了传达会议的精神
public class TeacherReceiver extends BroadcastReceiver {
@Override
public void onReceive(Context context, Intent intent) {
// TODO Auto-generated method stub
//String spirit = intent.getExtras().getString("SPORT_MEET");
String spirit = getResultData();
Log.i("TeacherReceiver", "院长说: "+spirit);
//因为太忙,忘了,也就不传播会议精神了
abortBroadcast();
//setResultData("每一个学生早上6点必须上早操");
}
}
结果为:
导员没有给班长传达会议精神,同学们也没收到, 当然也没人去上早操。可是学生会还是会说到终于的广播消息的。
注意: 假设你发送的是无序广播的话,使用abortBroadcast();是无法终止广播的传送的,对无序广播是没实用的。
相同setResultData也是对无序广播没实用的。
这个大家能够试试。
Android 四大组件学习之BroadcastReceiver三的更多相关文章
- Android 四大组件学习之BroadcastReceiver一
本节课学习四大组件最后一个, 广播接受者. 顾名思义广播接受者就是接受广播呗.比方在现实社会中,曾经每一个人家都有一台收音机,这可就能够去接受广播发出来的消息.大家都知道.程序世界也是參照的显示生活设 ...
- Android 四大组件学习之BroadcastReceiver二
上节学习了怎样创建一个广播.也尝试接受系统打电话的广播. 本节课学习怎样自己定义广播.自己定义广播实质上也就是创建一个发送广播者,创建一个接受该广播者. 那我们就開始行动吧. 先创建一个发送广播的应用 ...
- Android 四大组件学习之BroadcastReceiver四
本节学习系统中特殊的广播接收者. 我们前面几节不是说了,当广播接受者一旦注冊到系统中,当系统发送的广播和你注冊的广播的action匹配时,系统就会启动广播接收者所在的进程.除非用户手动停止广播接收者所 ...
- Android 四大组件学习之ContentProvider三
上节课学习怎样自己创建一个ContentProvider.以及用ContentResolver去操作ContentProvider. 今天我们用系统提供的ContentProvider. 先来个简单的 ...
- android四大组件学习总结以及各个组件示例(1)
android四大组件分别为activity.service.content provider.broadcast receiver. 一.android四大组件详解 1.activity (1)一个 ...
- Android 四大组件学习之Server一
上次学习了Android四大组件Activity之后,我们深刻理解了Activity.这次我们学习四大组件Service. Service与Activity的级别是一样的,都是Android系统不可缺 ...
- Android四大组件之一:BroadCastReceiver(广播接收者)
广播接受者是(BroadCastReceiver)是Android中的地大组件之一,之前学习了一些关于BroadCastReceiver方面的知识,今天回过头来发现已经快忘记的差不多了,毕竟现在是刚开 ...
- Android 四大组件学习之ContentProvider二
上节学习了什么是ContentProvider.以及ContentProvider的作用.以及什么是URL.本节就对上节学习的知识做一个实践,也就是定义自己的ContentProvider 好.实践是 ...
- android四大组件学习总结以及各个组件示例(2)
上篇博文讲解了activity.content provider,此篇博文来仔细总结service.broadcast receiver: 3. Service >什么是服务?>windo ...
随机推荐
- 体感设备:因特尔 Intel RealSense R200,乐视LeTV Pro Xtion和Orb奥比中光bec Astra比较
最近调试三个个厂家的体感设备,第一个是Intel的RealSense R200(参数规格:分辨率:1080p,深度有效距离:0.51-4,USB3.0),第二个是乐视LeTV Pro Xtion(参数 ...
- Node.js学习笔记(1) - Node.js简介
近期在看一些Node.js的知识,看完后觉得,一些前面的东西忘记了,于是整理一下,方便自己查阅,也希望对学习Node.js的朋友有些帮助: 当然以下只是我个人的观点和理解,不喜勿喷,也望大神指教. 一 ...
- Java中常见的IO流及其使用
Java中IO流分成两大类,一种是输入流.全部的输入流都直接或间接继承自InputStream抽象类,输入流作为数据的来源.我们能够通过输入流的read方法读取字节数据.还有一种是输出流,全部的输出流 ...
- Tasker to auto record incoming or outgoing call
Tasker to auto record incoming or outgoing call most of time, i was thinking of tasker can do the jo ...
- STM32F4: GENERATING A SINE WAVE
http://amarkham.com/?p=49
- ZOJ3673:1729
1729 is the natural number following 1728 and preceding 1730. It is also known as the Hardy-Ramanuja ...
- Property Finder – a Cross-Platform Xamarin MonoTouch Mobile App
Developers are now finding themselves having to author applications for a diverse range of mobile pl ...
- Spring使用环境变量控制配置文件加载(转)
项目中需要用到很多配置文件,不同环境的配置文件是不一样的,因此如果只用一个配置文件,势必会造成配置文件混乱,这里提供一种利用环境变量控制配置文件加载的方法,如下: 一.配置环境变量 如果是window ...
- Android跳转各种系统设置界面-总结
来自:http://www.jcodecraeer.com/a/anzhuokaifa/androidkaifa/2017/0921/8536.html View btn1 = this.findVi ...
- Java 复制大文件方式(nio2 FileChannel 拷贝文件能力测试)
目前为止,我们已经学习了很多 Java 拷贝文件的方式,除了 FileChannel 提供的方法外,还包括使用 Files.copy() 或使用字节数组的缓冲/非缓冲流.那个才是最好的选择呢?这个问题 ...