• android: 发送自定义广播


    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 之后确实是终止传递了。

  • 相关阅读:
    电话线路使用的带通虑波器的宽带为3KHz (300~3300Hz),根据奈奎斯特采样定理,最小采样频率应为(16)。
    总线宽度为32bit,时钟频率为200MHz,若总线上每5个时钟周期传送一个32bit的字,则该总线的带宽为 (4) MB/S。
    安全需求可划分为物理安全、网络安全、系统安全和应用安全,下面的安全需求中属于系统安全的是(67),属于应用安全的是(68)。
    IP地址202.117.17.254/22是什么地址?
    公司的到一个B类地址块,需要划分成若干个包含1000台主机的子网,则可以划分成几个?
    PGP(Pretty Good Privacy)是一种电子邮件加密软件包,它提供数据加密和数字签名两种服务,采用(42)进行身份认证,使用(43) (128位密钥)进行数据加密,使用(44)进行数据完整性验证。 A.RSA公钥证书 B.RSA私钥证书 C.Kerboros证书 D.DES私钥证书
    comet反向Ajax模型原理与模型(笔记一)
    EasyARM-iMX257_U-Boot源代码移植分析
    linux移植u-boot(一)——U-Boot详解+自定义命令实战
    Ajax实现大文件切割上传
  • 原文地址:https://www.cnblogs.com/zgqys1980/p/5178951.html
Copyright © 2020-2023  润新知