android: 发送自定义广播
5.3.1??? 發(fā)送標(biāo)準(zhǔn)廣播
?
在發(fā)送廣播之前,我們還是需要先定義一個廣播接收器來準(zhǔn)備接收此廣播才行,不然發(fā) 出去也是白發(fā)。因此新建一個 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();
}
}
這里當(dāng) 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 的廣播,因此待會兒在發(fā)送廣播的時候,我們就需要發(fā)出這樣的一條廣播。
接下來修改 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>
這里在布局文件中定義了一個按鈕,用于作為發(fā)送廣播的觸發(fā)點。然后修改 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);
}
……
}
可以看到,我們在按鈕的點擊事件里面加入了發(fā)送自定義廣播的邏輯。首先構(gòu)建出了一 個 Intent 對象,并把要發(fā)送的廣播的值傳入,然后調(diào)用了 Context 的 sendBroadcast()方法將廣 播發(fā)送出去,這樣所有監(jiān)聽 com.example.broadcasttest.MY_BROADCAST 這條廣播的廣播接 收器就會收到消息。此時發(fā)出去的廣播就是一條標(biāo)準(zhǔn)廣播。
重新運行程序,并點擊一下 Send Broadcast 按鈕,效果如圖 5.7 所示。
?
圖? ?5.7
?
這樣我們就成功完成了發(fā)送自定義廣播的功能。另外,由于廣播是使用 Intent 進行傳遞 的,因此你還可以在 Intent 中攜帶一些數(shù)據(jù)傳遞給廣播接收器。
?
5.3.2??? 發(fā)送有序廣播
?
廣播是一種可以跨進程的通信方式,這一點從前面接收系統(tǒng)廣播的時候就可以看出來 了。因此在我們應(yīng)用程序內(nèi)發(fā)出的廣播,其他的應(yīng)用程序應(yīng)該也是可以收到的。為了驗證這 一點,我們需要再新建一個 BroadcastTest2 項目。
將項目創(chuàng)建好之后,還需要在這個項目下定義一個廣播接收器,用于接收上一小節(jié)中的 自定義廣播。新建 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 這條廣播。現(xiàn)在運行 BroadcastTest2 項目將這個程序安裝到模擬器上,然 后重新回到 BroadcastTest 項目的主界面,并點擊一下 Send Broadcast 按鈕,就會分別彈出兩 次提示信息,如圖 5.8 所示。
圖? ?5.8
?
這樣就強有力地證明了,我們的應(yīng)用程序發(fā)出的廣播是可以被其他的應(yīng)用程序接收到的。
不過到目前為止,程序里發(fā)出的都還是標(biāo)準(zhǔn)廣播,現(xiàn)在我們來嘗試一下發(fā)送有序廣播。 關(guān)閉 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);
?
}
……
}
可 以 看 到 , 發(fā) 送 有 序 廣 播 只 需 要 改 動 一 行 代 碼 , 即 將 sendBroadcast() 方 法 改 成 sendOrderedBroadcast()方法。sendOrderedBroadcast()方法接收兩個參數(shù),第一個參數(shù)仍然是 Intent,第二個參數(shù)是一個與權(quán)限相關(guān)的字符串,這里傳入 null 就行了。現(xiàn)在重新運行程序, 并點擊 Send Broadcast 按鈕,你會發(fā)現(xiàn),兩個應(yīng)用程序仍然都可以接收到這條廣播。
看上去好像和標(biāo)準(zhǔn)廣播沒什么區(qū)別嘛,不過別忘了,這個時候的廣播接收器是有先后順 序的,而且前面的廣播接收器還可以將廣播截斷,以阻止其繼續(xù)傳播。
那么該如何設(shè)定廣播接收器的先后順序呢?當(dāng)然是在注冊的時候進行設(shè)定的了,修改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 屬性給廣播接收器設(shè)置了優(yōu)先級,優(yōu)先級比較高的 廣播接收器就可以先收到廣播。這里將 MyBroadcastReceiver 的優(yōu)先級設(shè)成了 100,以保證它 一定會在 AnotherBroadcastReceiver 之前收到廣播。
既然已經(jīng)獲得了接收廣播的優(yōu)先權(quán),那么 MyBroadcastReceiver 就可以選擇是否允許廣 播繼續(xù)傳遞了。修改 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()方法中調(diào)用了 abortBroadcast()方法,就表示將這條廣播截斷,后面的 廣播接收器將無法再接收到這條廣播。現(xiàn)在重新運行程序,并點擊一下 Send Broadcast 按鈕, 你 會 發(fā) 現(xiàn) , 只 有 MyBroadcastReceiver 中 的 Toast 信 息 能 夠 彈 出 , 說 明 這 條 廣 播 經(jīng) 過 MyBroadcastReceiver 之后確實是終止傳遞了。
轉(zhuǎn)載于:https://www.cnblogs.com/zgqys1980/p/5178951.html
總結(jié)
以上是生活随笔為你收集整理的android: 发送自定义广播的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 编程题A+B Format的总结(第二次
- 下一篇: [华为机试练习题]55.最大公约数 am