Broadcast(廣播)是Android四大組件之一,正如其名,就像一個(gè)廣播喇叭一樣,起著進(jìn)程間,或進(jìn)程內(nèi)部傳遞消息的作用。
BroadcastReceiver(廣播接收器)有兩種生成方式,靜態(tài)注冊(cè)和動(dòng)態(tài)注冊(cè),靜態(tài)注冊(cè)就是在xml中注冊(cè),動(dòng)態(tài)注冊(cè)就是在activity中注冊(cè),
BroadcastReceiver有兩種范圍,一種是進(jìn)程間,如android很多內(nèi)置的系統(tǒng)級(jí)廣播,可以在系統(tǒng)的各個(gè)位置任意時(shí)段接受,另一種是本地廣播,只能作用于某一個(gè)應(yīng)用程序內(nèi)部,一般我們用這種即可,以免導(dǎo)致一些不必要的凌亂。
BroadcastReceiver有兩個(gè)類別,一個(gè)標(biāo)準(zhǔn)廣播,速度快,所有接收器幾乎同時(shí)接收而沒(méi)有順序。另一種是有序廣播,可以有序的接收,并攔截。
下面我們分類探討一下。
在接收廣播前,很顯然要先生成一條廣播:
IntentFilter mIntentFilter = new IntentFilter();
mIntentFilter.addAction(“android.net.conn.CONNECTIVITY_CHANGE”);
registerReceiver(mReceiver,mIntent);
這里新建了一個(gè)IntentFilter,addAction接收的參數(shù)就是具體要監(jiān)聽(tīng)的廣播,緊接著注冊(cè)這個(gè)接收器。
在這個(gè)Activity的onDestroy()方法中:
unregisterReceiver(mReceiver);
銷毀接收器
在這里新建一個(gè)類并繼承BroadcastReceiver(廣播接收器),并重寫(xiě)onReceiver()方法
classNetworkChangeReceiverextendsBroadcastReceiver{
@Override
public voidonReceive(Context context,Intent intent) {
Toast.makeText(context,"network
changes",Toast.LENGTH_SHORT).show();
}
}
這里在activity中寫(xiě)了一個(gè)內(nèi)部類,繼承BroadcastReceiver,在onReceive()方法中寫(xiě)具體邏輯,這里只打印一個(gè)吐司。
注意,這里實(shí)際上就是一個(gè)動(dòng)態(tài)的在activity中注冊(cè)一個(gè)廣播接收器。
靜態(tài)注冊(cè)。
動(dòng)態(tài)注冊(cè)很顯然只有你程序啟動(dòng)以后才能使用,因?yàn)樽?cè)是寫(xiě)在onCreate()中的,靜態(tài)注冊(cè)就可以各個(gè)時(shí)段使用。
首先,和動(dòng)態(tài)注冊(cè)差不多的一件事,就是新建一個(gè)類,繼承BroadcastReceiver并重寫(xiě)onReceiver()方法。
public classBootCompleteReceiverextendsBroadcastReceiver {
public voidonReceive(Context context,Intent intent){
Toast.makeText(context,"BootComplete",Toast.LENGTH_SHORT).show();
}
}
這是一個(gè)監(jiān)聽(tīng)開(kāi)機(jī)啟動(dòng)的一個(gè)廣播接收器,我們?cè)贏ndroidManifest.xml文件中,聲明一個(gè)監(jiān)聽(tīng)開(kāi)機(jī)啟動(dòng)的intentFilter
在標(biāo)簽內(nèi)寫(xiě)入:
這實(shí)際上就是,xml版的IntentFilter
接著,action這里的值是"android.intent.action.BOOT_COMPLETED",這里監(jiān)聽(tīng)了系統(tǒng)開(kāi)機(jī),這種系統(tǒng)級(jí)信息的監(jiān)聽(tīng)或服務(wù)都是需要聲明權(quán)限的,所以,在最開(kāi)始我們就寫(xiě)入:
自定義廣播
關(guān)鍵在于監(jiān)聽(tīng)的action的值,兩邊不寫(xiě)錯(cuò)即可,其他的都差不多
有序廣播
之前寫(xiě)的都是標(biāo)準(zhǔn)廣播,是沒(méi)有接收順序,也不能攔截的,有序廣播與此不同。
發(fā)送有序廣播和標(biāo)準(zhǔn)廣播的操作大體不差,首先要有廣播,這里就直接定義一個(gè)接收器,然后在AndroidMainfest.xml中注冊(cè)一個(gè)自定義廣播:
public classAnotherBroadcastReceiverextendsBroadcastReceiver {
@Override
public voidonReceive(Context context,Intent intent) {
Toast.makeText(context,"received in AnotherBroadcastReceiver",Toast.LENGTH_SHORT).show();
abortBroadcast();
}
}
>
然后再某一個(gè)activity中:
IntentmIntent =newIntent("com.example.broadcasttest.MY_BROADCAST");
sendOrderedBroadcast(mIntent, null);
可見(jiàn),唯一的區(qū)別就是調(diào)用的時(shí)候,方法變了,還有注冊(cè)的時(shí)候多了一個(gè)android:priority
屬性,這個(gè)屬性的值越大,優(yōu)先級(jí)越高,越先收到廣播
abortBroadcast();
方法用來(lái)攔截廣播,禁止繼續(xù)傳遞。
本地廣播
以上,都是全局廣播,也就是說(shuō)所有的程序都有可能受到,自然是有很大隱患的。所以一般我們用本地廣播
本地廣播的初始化方式也很想,無(wú)非就是類不一樣:
privateIntentFilterintentFilter;
privateLocalBroadcastManagermanager; //管理本地廣播
LocalBroadcastReceiver localBroadcastReceiver =newLocalBroadcastReceiver();
manager= LocalBroadcastManager.getInstance(this);//獲取實(shí)例
manager.sendBroadcast(mIntent);
intentFilter=newIntentFilter();
intentFilter.addAction(" ...... ");
manager.registerReceiver(localBroadcastReceiver,intentFilter);
在onCreate()方法中,首先new一個(gè)IntentFilter,receiver,然后拿到manager的實(shí)例,調(diào)用localBroadcastReceiver.registerReceiver()注冊(cè),這樣,就是注冊(cè)了一個(gè)本地廣播接收器,不要忘了在onDestroy()中釋放就好。