編輯:關於Android編程
Android系統的4個組件終於還剩一種組件了BroadcastReceiver,這個組件是全局監聽器,可以監聽系統全局的廣播消息,可以方便的實現系統中不同組件之間的通信
BroadcastReceiver有自己的進程,系統級監聽器,只要存在與之匹配的Intent被廣播出來,BroadcastReceiver就會被激發要創建自己的BroadcastReceiver對象,我們需要繼承android.content.BroadcastReceiver,並實現其onReceive方法
MyReceiver.java
public class MyReceiver extends BroadcastReceiver { @Override public void onReceive(Context context, Intent intent) { Toast.makeText(context, "接收到的Intent的Action為:" + intent.getAction() + "\n消息內容是:" + intent.getStringExtra("msg") , Toast.LENGTH_LONG).show(); } }Manifest.xml清單文件配置的receiver
就是說無論哪個組件中,intent的Action是"org.crazyit.action.CRAZY_BROADCAST" 並使用使用sendBroadcast(intent)發出廣播,那麼MyReceiver就會被啟動
public class BroadcastMain extends Activity { Button send; @Override public void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.main); // 獲取程序界面中的按鈕 send = (Button) findViewById(R.id.send); send.setOnClickListener(new OnClickListener() { @Override public void onClick(View v) { // 創建Intent對象 Intent intent = new Intent(); // 設置Intent的Action屬性 intent.setAction("org.crazyit.action.CRAZY_BROADCAST"); intent.putExtra("msg", "簡單的消息"); // 發送廣播 sendBroadcast(intent); } }); } }
注冊Receiver有兩種方法:
靜態注冊
靜態注冊是在AndroidManifest.xml文件中配置的,我們就來為MyReceiver注冊一個廣播地址:
配置了以上信息之後,只要是android.intent.action.MY_BROADCAST這個地址的廣播,MyReceiver都能夠接收的到。注意,這種方式的注冊是常駐型的,也就是說當應用關閉後,如果有廣播信息傳來,MyReceiver也會被系統調用而自動運行。
動態注冊
動態注冊需要在代碼中動態的指定廣播地址並注冊,通常我們是在Activity或Service注冊一個廣播,下面我們就來看一下注冊的代碼:
MyReceiver receiver = new MyReceiver(); IntentFilter filter = new IntentFilter(); filter.addAction("android.intent.action.MY_BROADCAST"); registerReceiver(receiver, filter); //注冊
receiver 和filter
普通廣播
普通廣播對於多個接收者來說是完全異步的,通常每個接收者都無需等待即可以接收到廣播,接收者相互之間不會有影響。對於這種廣播,接收者無法終止廣播,即無法阻止其他接收者的接收動作。上面的例子就是發送的普通廣播
有序廣播
有序廣播比較特殊,它每次只發送到優先級較高的接收者那裡,然後由優先級高的接受者再傳播到優先級低的接收者那裡,優先級高的接收者有能力終止這個廣播。
例如:優先級A>B>C,Broadcast先傳給A,再傳給B,在傳給C。優先級別聲明
優先收到Broadcast的接受者可以通過setResultExtras(Bundle)方法將處理結果存入Broadcast中,然後傳給下一個接受者,通過Bundle bunde=getResultExtras(true)柯獲得上一個接受者存入的數據
public class SortedBroadcast extends Activity { Button send; @Override public void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.main); // 獲取程序中的send按鈕 send = (Button) findViewById(R.id.send); send.setOnClickListener(new OnClickListener() { @Override public void onClick(View v) { // 創建Intent對象 Intent intent = new Intent(); intent.setAction("org.crazyit.action.CRAZY_BROADCAST"); intent.putExtra("msg", "簡單的消息"); // 發送有序廣播 sendOrderedBroadcast(intent, null); } }); } }MyReceiver.java
public class MyReceiver extends BroadcastReceiver { @Override public void onReceive(Context context, Intent intent) { Toast.makeText(context, "接收到的Intent的Action為:" + intent.getAction() + "\n消息內容是:" + intent.getStringExtra("msg") , Toast.LENGTH_LONG).show(); // 創建一個Bundle對象,並存入數據 Bundle bundle = new Bundle(); bundle.putString("first", "第一個BroadcastReceiver存入的消息"); // 將bundle放入結果中 setResultExtras(bundle); // 取消Broadcast的繼續傳播 // abortBroadcast(); //① } }MyReceiver2.java
public class MyReceiver2 extends BroadcastReceiver { @Override public void onReceive(Context context, Intent intent) { Bundle bundle = getResultExtras(true); // 解析前一個BroadcastReceiver所存入的key為first的消息 String first = bundle.getString("first"); Toast.makeText(context, "第一個Broadcast存入的消息為:" + first, Toast.LENGTH_LONG).show(); } }清單文件
在之前的基礎上 在 res 文件夾下面: 添加一個 drawable/local_me.xml localme_cml 主程序: p
ShaderShader是一個基類,表示在繪制期間顏色的水平跨度它的子類被嵌入在Paint中使用,調用paint.setShader(shader)。除Bit
主要實現制作聊天的登錄界面,並且能實現記住密碼功能。效果如如下:1.WlainChat的布局文件,使用TableLayout布局(login.xml)
在Android開發中,我們經常會需要在Android界面上彈出一些對話框,比如詢問用戶或者讓用戶選擇。這些功能我們叫它Android Dialog對話框,AlertDi