本文主要是介绍android-学习篇-BroadcastReceiver(广播),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!
文章目录
- 简介
- 接收广播
- 发送广播
- 通过权限限制广播
- 对进程状态的影响
- 参考
简介
Android 应用与系统和其他应用之间可以相互收发广播消息,这与发布-订阅设计模式相似。这些广播会在所关注的事件发生时发送。
接收广播
由于接收器的 onReceive(Context, Intent) 方法在主线程上运行,因此它会快速执行并返回。广播接收操作在10秒内完成。
方式一 清单文件中声名
<receiver android:name=".MyBroadcastReceiver" android:exported="true"><intent-filter><action android:name="android.intent.action.BOOT_COMPLETED"/><action android:name="android.intent.action.INPUT_METHOD_CHANGED" /></intent-filter></receiver>
创建 BroadcastReceiver 子类并实现 onReceive(Context, Intent)。
方式二 上下文注册
BroadcastReceiver br = new MyBroadcastReceiver();IntentFilter filter = new IntentFilter(ConnectivityManager.CONNECTIVITY_ACTION);
filter.addAction(Intent.ACTION_AIRPLANE_MODE_CHANGED);
this.registerReceiver(br, filter);// 注册// 停止接收广播,请调用 unregisterReceiver(android.content.BroadcastReceiver)。
// 当您不再需要接收器或上下文不再有效时,请务必注销接收器。
只要注册上下文有效,上下文注册的接收器就会接收广播。例如,如果您在 Activity 上下文中注册,只要 Activity 没有被销毁,您就会收到广播。如果您在应用上下文中注册,只要应用在运行,您就会收到广播。
请注意注册和注销接收器的位置,比方说,如果您使用 Activity 上下文在 onCreate(Bundle) 中注册接收器,则应在 onDestroy() 中注销,以防接收器从 Activity 上下文中泄露出去。如果您在 onResume() 中注册接收器,则应在 onPause() 中注销,以防多次注册接收器(如果您不想在暂停时接收广播,这样可以减少不必要的系统开销)。请勿在 onSaveInstanceState(Bundle) 中注销,因为如果用户在历史记录堆栈中后退,则不会调用此方法。
发送广播
// 一次向一个接收器发送广播
sendOrderedBroadcast(Intent, String)
// 按随机的顺序向所有接收器发送广播
sendBroadcast(Intent)
// 将广播发送给与发送器位于同一应用中的接收器。如果不需要跨应用发送广播,请使用本地广播。这种实现方法的效率更高(无需进行进程间通信),而且您无需担心其他应用在收发您的广播时带来的任何安全问题。
LocalBroadcastManager.sendBroadcast
Intent intent = new Intent();
intent.setAction("com.example.broadcast.MY_NOTIFICATION");
intent.putExtra("data", "Notice me senpai!");
sendBroadcast(intent);
通过权限限制广播
带权限的发送
sendBroadcast(new Intent("com.example.NOTIFY"), Manifest.permission.SEND_SMS);// 接收方必须申请权限
// 可以指定现有的系统权限,也可以使用 <permission> 元素定义自定义权限。
<uses-permission android:name="android.permission.SEND_SMS"/>
注意:自定义权限将在安装应用时注册。定义自定义权限的应用必须在使用自定义权限的应用之前安装。
带权限的接收
<receiver android:name=".MyBroadcastReceiver"android:permission="android.permission.SEND_SMS"><intent-filter><action android:name="android.intent.action.AIRPLANE_MODE"/></intent-filter></receiver>
IntentFilter filter = new IntentFilter(Intent.ACTION_AIRPLANE_MODE_CHANGED);registerReceiver(receiver, filter, Manifest.permission.SEND_SMS, null );
发送方需要请求权限,才能向上面的接收器发送广播
<uses-permission android:name="android.permission.SEND_SMS"/>
对进程状态的影响
不应从广播接收器启动长时间运行的后台线程。onReceive() 完成后,系统可以随时终止进程来回收内存,在此过程中,也会终止进程中运行的派生线程。要避免这种情况,您应该调用 goAsync()(如果您希望在后台线程中多花一点时间来处理广播)或者使用 JobScheduler 从接收器调度 JobService,这样系统就会知道该进程将继续活跃地工作。
public class MyBroadcastReceiver extends BroadcastReceiver {private static final String TAG = "MyBroadcastReceiver";@Overridepublic void onReceive(Context context, Intent intent) {final PendingResult pendingResult = goAsync();Task asyncTask = new Task(pendingResult, intent);asyncTask.execute();}private static class Task extends AsyncTask<String, Integer, String> {private final PendingResult pendingResult;private final Intent intent;private Task(PendingResult pendingResult, Intent intent) {this.pendingResult = pendingResult;this.intent = intent;}@Overrideprotected String doInBackground(String... strings) {StringBuilder sb = new StringBuilder();sb.append("Action: " + intent.getAction() + "\n");sb.append("URI: " + intent.toUri(Intent.URI_INTENT_SCHEME).toString() + "\n");String log = sb.toString();Log.d(TAG, log);return log;}@Overrideprotected void onPostExecute(String s) {super.onPostExecute(s);// Must call finish() so the BroadcastReceiver can be recycled.pendingResult.finish();}}}
参考
- android开发者
这篇关于android-学习篇-BroadcastReceiver(广播)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!