5.3.1    发送标准广播

在发送广播之前,我们还是需要先定义一个广播接收器来准备接收此广播才行,不然发 出去也是白发。因此新建一个 MyBroadcastReceiver 继承自 BroadcastReceiver,代码如下所示:

public class MyBroadcastReceiver extends BroadcastReceiver {

@Override

public void onReceive(Context context, Intent intent) { Toast.makeText(context, "received in MyBroadcastReceiver",

Toast.LENGTH_SHORT).show();

}

}

这里当 MyBroadcastReceiver 收到自定义的广播时,就会弹出 received in MyBroadcastReceiver的提示。然后在 AndroidManifest.xml 中对这个广播接收器进行注册:

<manifest xmlns:android="http://schemas.android.com/apk/res/android" package="com.example.broadcasttest"

android:versionCode="1" android:versionName="1.0" >

……

<application android:allowBackup="true" android:icon="@drawable/ic_launcher" android:label="@string/app_name" android:theme="@style/AppTheme" >

……

<receiver android:name=".MyBroadcastReceiver">

<intent-filter>

<action android:name="com.example.broadcasttest. MY_BROADCAST"/>

</intent-filter>

</receiver>

</application>

</manifest>

可 以 看 到 , 这 里 让 MyBroadcastReceiver 接 收 一 条 值 为 com.example.broadcasttest. MY_BROADCAST 的广播,因此待会儿在发送广播的时候,我们就需要发出这样的一条广播。

接下来修改 activity_main.xml 中的代码,如下所示:

<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android" android:layout_width="match_parent" android:layout_height="match_parent" >

<Button android:id="@+id/button" android:layout_width="match_parent" android:layout_height="wrap_content" android:text="Send Broadcast"/>

</LinearLayout>

这里在布局文件中定义了一个按钮,用于作为发送广播的触发点。然后修改 MainActivity中的代码,如下所示:

public class MainActivity extends Activity {

……

@Override

protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.activity_main);

Button button = (Button) findViewById(R.id.button);

button.setOnClickListener(new OnClickListener() {

@Override

public void onClick(View v) {

Intent intent = new Intent("com.example.broadcasttest.MY_BROADCAST");

}

});

……

sendBroadcast(intent);

}

……

}

可以看到,我们在按钮的点击事件里面加入了发送自定义广播的逻辑。首先构建出了一 个 Intent 对象,并把要发送的广播的值传入,然后调用了 Context 的 sendBroadcast()方法将广 播发送出去,这样所有监听 com.example.broadcasttest.MY_BROADCAST 这条广播的广播接 收器就会收到消息。此时发出去的广播就是一条标准广播。

重新运行程序,并点击一下 Send Broadcast 按钮,效果如图 5.7 所示。

图   5.7

这样我们就成功完成了发送自定义广播的功能。另外,由于广播是使用 Intent 进行传递 的,因此你还可以在 Intent 中携带一些数据传递给广播接收器。

5.3.2    发送有序广播

广播是一种可以跨进程的通信方式,这一点从前面接收系统广播的时候就可以看出来 了。因此在我们应用程序内发出的广播,其他的应用程序应该也是可以收到的。为了验证这 一点,我们需要再新建一个 BroadcastTest2 项目。

将项目创建好之后,还需要在这个项目下定义一个广播接收器,用于接收上一小节中的 自定义广播。新建 AnotherBroadcastReceiver 继承自 BroadcastReceiver,代码如下所示:

public class AnotherBroadcastReceiver extends BroadcastReceiver {

@Override

public void onReceive(Context context, Intent intent) { Toast.makeText(context, "received in AnotherBroadcastReceiver",

Toast.LENGTH_SHORT).show();

}

}

这 里 仍 然 是 在 广 播 接 收 器 的 onReceive() 方 法 中 弹 出 了 一 段 文 本 信 息 。 然 后 在AndroidManifest.xml 中对这个广播接收器进行注册,代码如下所示:

<manifest xmlns:android="http://schemas.android.com/apk/res/android" package="com.example.broadcasttest2"

android:versionCode="1"

android:versionName="1.0" >

……

<application android:allowBackup="true" android:icon="@drawable/ic_launcher" android:label="@string/app_name" android:theme="@style/AppTheme" >

……

<receiver android:name=".AnotherBroadcastReceiver" >

<intent-filter>

<action android:name="com.example.broadcasttest.MY_BROADCAST" />

</intent-filter>

</receiver>

</application>

</manifest>

可 以 看 到 , AnotherBroadcastReceiver 同 样 接 收 的 是 com.example.broadcasttest. MY_BROADCAST 这条广播。现在运行 BroadcastTest2 项目将这个程序安装到模拟器上,然 后重新回到 BroadcastTest 项目的主界面,并点击一下 Send Broadcast 按钮,就会分别弹出两 次提示信息,如图 5.8 所示。

图   5.8

这样就强有力地证明了,我们的应用程序发出的广播是可以被其他的应用程序接收到的。

不过到目前为止,程序里发出的都还是标准广播,现在我们来尝试一下发送有序广播。 关闭 BroadcastTest2 项目,然后修改 MainActivity 中的代码,如下所示:

public class MainActivity extends Activity {

……

@Override

protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.activity_main);

Button button = (Button) findViewById(R.id.button);

button.setOnClickListener(new OnClickListener() {

@Override

public void onClick(View v) {

Intent intent = new Intent("com.example.broadcasttest.MY_BROADCAST");

}});

sendOrderedBroadcast(intent, null);

}

……

}

可 以 看 到 , 发 送 有 序 广 播 只 需 要 改 动 一 行 代 码 , 即 将 sendBroadcast() 方 法 改 成 sendOrderedBroadcast()方法。sendOrderedBroadcast()方法接收两个参数,第一个参数仍然是 Intent,第二个参数是一个与权限相关的字符串,这里传入 null 就行了。现在重新运行程序, 并点击 Send Broadcast 按钮,你会发现,两个应用程序仍然都可以接收到这条广播。

看上去好像和标准广播没什么区别嘛,不过别忘了,这个时候的广播接收器是有先后顺 序的,而且前面的广播接收器还可以将广播截断,以阻止其继续传播。

那么该如何设定广播接收器的先后顺序呢?当然是在注册的时候进行设定的了,修改AndroidManifest.xml 中的代码,如下所示:

<manifest xmlns:android="http://schemas.android.com/apk/res/android" package="com.example.broadcasttest"

android:versionCode="1" android:versionName="1.0" >

……

<application android:allowBackup="true" android:icon="@drawable/ic_launcher" android:label="@string/app_name" android:theme="@style/AppTheme" >

……

<receiver android:name=".MyBroadcastReceiver">

<intent-filter android:priority="100" >

<action android:name="com.example.broadcasttest.MY_BROADCAST"/>

</intent-filter>

</receiver>

</application>

</manifest>

可以看到,我们通过 android:priority 属性给广播接收器设置了优先级,优先级比较高的 广播接收器就可以先收到广播。这里将 MyBroadcastReceiver 的优先级设成了 100,以保证它 一定会在 AnotherBroadcastReceiver 之前收到广播。

既然已经获得了接收广播的优先权,那么 MyBroadcastReceiver 就可以选择是否允许广 播继续传递了。修改 MyBroadcastReceiver 中的代码,如下所示:

public class MyBroadcastReceiver extends BroadcastReceiver {

@Override

public void onReceive(Context context, Intent intent) { Toast.makeText(context, "received in MyBroadcastReceive",

Toast.LENGTH_SHORT).show();

abortBroadcast();

}

}

如果在 onReceive()方法中调用了 abortBroadcast()方法,就表示将这条广播截断,后面的 广播接收器将无法再接收到这条广播。现在重新运行程序,并点击一下 Send Broadcast 按钮, 你 会 发 现 , 只 有 MyBroadcastReceiver 中 的 Toast 信 息 能 够 弹 出 , 说 明 这 条 广 播 经 过 MyBroadcastReceiver 之后确实是终止传递了。

android: 发送自定义广播的更多相关文章

  1. android 发送自定义广播以及接收自定义广播

    发送自定义广播程序: 布局文件: <?xml version="1.0" encoding="utf-8"?> <LinearLayout x ...

  2. Android 发送自定义广播(标准和本地)

    1.首先自定义一个广播接收器:MyBroadcastReceiver package example.com.mybroadcastreceiver; import android.content.B ...

  3. MIUI7,Android版本5.0.2,一个程序发送自定义广播,另一个程序没有接收到

    对照<第一行代码——Android>进行学习,第五章中说到广播包的相关知识,前面获取广播等程序例程都可以跑的通,但是在5.3.2节中,程序A发送自定义广播,并接收自定义广播,同时程序B也接 ...

  4. Android学习总结(六)———— 发送自定义广播

    一.两种广播类型 2.1 标准广播 是一种完全异步执行的广播,在广播发出去之后,所有的广播接收器几乎都会在同一时刻接收到这条广播消息,因此它们之间没有任何先后顺序可言.这种广播的效率会比较高,但同时也 ...

  5. android#boardcast#发送自定义广播

    广播主要分为两种类型,标准广播和有序广播,通过实践的方式来看下这两种广播具体的区别. 一.发送标准广播 在发送广播之前,我们还是需要先定义一个广播接收器来准备接收此广播才行,不然发出去也是白发.因此新 ...

  6. android 发送UDP广播,搜寻server建立socket链接

    应用场景:client(手机.pc)须要搜寻所在局域网内的server并获得server地址. 方法简单介绍:client发送UDP广播,服务收到广播后得到clientip地址,然后向client发送 ...

  7. android之自定义广播

    布局文件 点击按钮发送广播 <?xml version="1.0" encoding="utf-8"?> <LinearLayout xmln ...

  8. Android中自定义广播的实现

    今天尝试了自定义的广播,说是自定义的广播其实质就是自己编写一个类继承broadcastreceiver类,然后再onreceiver方法中实现某些功能,在这个过程中我们可以自定义我们要发出的广播,可以 ...

  9. Android入门(八)广播

    原文链接:http://www.orlion.ga/572/ 一.广播机制 Android中的每个应用程序都可以对自己感兴趣的广播进行注册,这样该程序就只会接收到自己所关心的广播内容,这些广 播可能是 ...

随机推荐

  1. PYTHON-函数对象,嵌套,名称空间与作用域,闭包函数

    一 函数是第一类对象,即函数可以当作数据传递 1 可以被引用 2 可以当作参数传递 3 返回值可以是函数 3 可以当作容器类型的元素 def foo(): return len f = foo pri ...

  2. VS2017项目程序打包成.msi或者.exe

    VS2017项目程序打包成.msi或者.exe 1.安装打包插件:Microsoft Visual Studio 2017 Installer Projects 打开vs2017 ,选择 工具 --& ...

  3. mysql的undo log和redo log

    在数据库系统中,既有存放数据的文件,也有存放日志的文件.日志在内存中也是有缓存Log buffer,也有磁盘文件log file,本文主要描述存放日志的文件.     MySQL中的日志文件,有这么两 ...

  4. pytest十:用例 a 失败,跳过测试用例 b 和 c 并标记失败 xfail

    当用例 a 失败的时候,如果用例 b 和用例 c 都是依赖于第一个用例的结果,那可以直接跳过用例 b 和 c 的测试,直接给他标记失败 xfail用到的场景,登录是第一个用例,登录之后的操作 b 是第 ...

  5. python 全栈开发,Day9(函数的初始,返回值,传参,三元运算)

    一.函数的初始 比如python没有len()方法,如何求字符串的长度使用for循环 s = 'fdshfeigjoglfkldsja' count = 0 for i in s: count += ...

  6. 《剑指offer》青蛙跳台阶

    题目描述 一只青蛙一次可以跳上1级台阶,也可以跳上2级.求该青蛙跳上一个n级的台阶总共有多少种跳法. 很裸的斐波那契数列. class Solution { public: int jumpFloor ...

  7. IntelliJ IDEA设置不自动打开最后关闭的项目

  8. POJ 3126 Prime Path (素数+BFS)

    题意:给两个四位素数a和b,求从a变换到b的最少次数,每次变换只能变换一个数字并且变换的过程必须也是素数. 思路:先打表求出四位长度的所有素数,然后利用BFS求解.从a状态入队,然后从个位往千位的顺序 ...

  9. BZOJ1051 [HAOI2006]受欢迎的牛 Tarjan 强连通缩点

    欢迎访问~原文出处——博客园-zhouzhendong 去博客园看该题解 题目传送门 - BZOJ1051 题意概括 有n只牛,有m个羡慕关系. 羡慕关系具有传递性. 如果A羡慕B,B羡慕C,那么我们 ...

  10. Redis数据结构之set

    一:介绍 1.set结构 没有顺序 并且,不允许出现重复的元素. 二:Redis客户端的常用命令 1.添加 2.查看数据 3.删除数据 4.是否存在某个值 1代表有,0代表无. 5.查看差值 有key ...