Android中BroadcastReceiver的使用
1、Android中广播分为静态注册和动态注册
2、下面是一个简单静态注册的例子
- 创建一个继承
BroadcastReceiver
的子类
public class DeviceBootReceiver extends BroadcastReceiver {
private static final String TAG = DeviceBootReceiver.class.getName();
@Override
public void onReceive(Context context, Intent intent) {
Log.d(TAG, "开机了:" + intent.getAction());
}
}
该类的功能用于接收手机开机的广播。
- 在
AndroidManifest.xml
中注册该组件
<receiver android:name=".DeviceBootReceiver">
<intent-filter>
<action android:name="android.intent.action.BOOT_COMPLETED" />
</intent-filter>
</receiver>
action
标签中的值用于匹配广播的类型,这里是开机广播。
这样当手机开机时,便会收到来自系统的消息。
同样,我们也可以监听应用安装,应用卸装,USB插拔等系统广播。只是action
的值稍有不同。
<receiver android:name=".OtherStateReceiver">
<intent-filter>
<!--电量过低-->
<action android:name="android.intent.action.BATTERY_LOW" />
<!--USB连接-->
<action android:name="android.intent.action.ACTION_POWER_CONNECTED"/>
<!--USB断开-->
<action android:name="android.intent.action.ACTION_POWER_DISCONNECTED" />
<!--软件包安装-->
<action android:name="android.intent.action.PACKAGE_ADDED" />
<!--软件包卸装-->
<action android:name="android.intent.action.PACKAGE_REMOVED" />
</intent-filter>
</receiver>
上面除了开机广播,其他广播这样注册能成功的前提是 API Level < 26(Android8.0以下)
。Google为了防止接收者程序常驻内存消耗资源,禁止了一些Manifest declared receiver
。我们想要继续监听,就要使用动态注册的方式。
3、下面是一个动态注册的例子:
public class SystemBroadcastReceiverActivity extends AppCompatActivity {
private SystemBroadcastReceiver receiver;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_system_broadcast_receiver);
IntentFilter filter = new IntentFilter();
//USB连接
filter.addAction(Intent.ACTION_POWER_CONNECTED);
//USB断开
filter.addAction(Intent.ACTION_POWER_DISCONNECTED);
receiver = new SystemBroadcastReceiver();
registerReceiver(receiver, filter);
}
private class SystemBroadcastReceiver extends BroadcastReceiver {
@Override
public void onReceive(Context context, Intent intent) {
System.out.println(intent.getAction());
}
}
@Override
protected void onDestroy() {
super.onDestroy();
unregisterReceiver(receiver);
}
}
然后在AndroidManifest.xml
注册该Activity
即可。
4、自定义广播
前面说的都是接收系统广播,我们也可以发送自定义的广播,然后在同一个应用或不同应用中接收。
下面是一个静态注册的自定义广播:
- 建立一个
Activity
,提供一个Button
,点击后发送广播
public class CustomSenderActivity extends AppCompatActivity {
public static final String BROADCAST_ACTION = "com.hncj.android.manifest.CustomSenderActivity";
public static final String BROADCAST_CONTENT = "broadcast_content";
@Override
protected void onCreate(@Nullable Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_custom_sender);
}
@SuppressLint("WrongConstant")
public void sendBroadcast(View view) {
Intent intent = new Intent();
intent.setAction(BROADCAST_ACTION);
intent.putExtra(BROADCAST_CONTENT, "我发送了广播,你看收没收到?");
//解决API26及以上的Android静态注册的Receiver收不到广播
//第一种解决方案:设置标志 Intent.FLAG_RECEIVER_INCLUDE_BACKGROUND
intent.addFlags(0x01000000); //不论是一个应用自己发自己收还是一个应用发一个应用收,都可以实现效果
//第二种解决方案:指定包名(这里是一个应用,自己发,自己收,都在一个包下)
//intent.setPackage(getPackageName()); //如果是给另一个应用发广播 则写成intent.setPackage("另一个项目应用接收者的包名");
//第三种解决方案: 明确指定包名,类名
//intent.setComponent(new ComponentName(this, CustomReceiver.class)); //如果是给另一个应用发广播 则写成 intent.setComponent(new ComponentName("另一个应用接收者包名", "另一个应用接收者类名"));
//发送广播
sendBroadcast(intent);
}
}
- 布局文件
<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:gravity="center"
android:orientation="vertical"
android:padding="40dp">
<Button
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:onClick="sendBroadcast"
android:background="#008080"
android:textSize="30dp"
android:text="发送广播"></Button>
</LinearLayout>
- 接收者
public class CustomReceiver extends BroadcastReceiver {
private static final String TAG = CustomReceiver.class.getName();
@Override
public void onReceive(Context context, Intent intent) {
String action = intent.getAction();
Log.d(TAG, "我收到了来自" + action + "的广播");
}
}
AndroidManifest.xml
文件
<activity android:name=".manifest.CustomSenderActivity">
<intent-filter>
<action android:name="android.intent.action.MAIN" />
<category android:name="android.intent.category.LAUNCHER" />
</intent-filter>
</activity>
<receiver android:name=".manifest.CustomReceiver">
<intent-filter>
<action android:name="com.hncj.android.manifest.CustomSenderActivity" />
</intent-filter>
</receiver>
这里的一个接收者是在当前项目,还有一个接收者在另一个项目,代码基本是一致的。
相关的API:
发送有序广播:
<!--广播中携带数据-->
Bundle bundle = new Bundle();
bundle.putString("username", "nacy");
sendOrderedBroadcast(intent, null, null, null, Activity.RESULT_OK, null, bundle);
为接收者设置优先级:(-1000-1000),即定义哪个接收者先收到,优先级越大,越早收到广播
<receiver android:name=".manifest.CustomReceiver">
<!--priority可以设置优先级-->
<intent-filter android:priority="9">
<action android:name="com.hncj.android.manifest.CustomSenderActivity" />
</intent-filter>
</receiver>
终止广播:
<!--广播不再向下传递-->
abortBroadcast();
取出广播中的数据:
//取出Bundle对象,类似于一个map
Bundle bundle = getResultExtras(true);
设置接收者权限:(谁能收到)
- 先在发送方
AndroidManifest.xml
中声明一个权限(包名+权限名)
<permission android:name="com.hncj.android.RECEIVER_PERMISSION" />
- 发送时定义接收者需要拥有的权限:
sendOrderedBroadcast(intent, Manifest.permission.RECEIVER_PERMISSION, null, null, Activity.RESULT_OK, null, bundle);
- 接收者需要在
AndroidManifest.xml
使用权限:
<uses-permission android:name="com.hncj.android.RECEIVER_PERMISSION" />
设置发送者权限:(谁能给我发)
- 先在接收方
AndroidManifest.xml
声明一个权限
<permission android:name="com.hncj.android.SENDER_PERMISSION" />
- 在Receiver标签中说明发送者要拥有的权限:
<receiver android:name=".manifest.CustomReceiver" android:permission="com.hncj.android.SENDER_PERMISSION">
<intent-filter android:priority="9">
<action android:name="com.hncj.android.manifest.CustomSenderActivity" />
</intent-filter>
</receiver>
- 在发送方
AndroidManifest.xml
中使用权限
<uses-permission android:name="com.hncj.android.SENDER_PERMISSION" />
还有动态注册的自定义广播,与上面提到的动态注册的例子差不多,只是自定义action的内容。
Android中BroadcastReceiver的使用的更多相关文章
- Android中BroadcastReceiver的两种注册方式(静态和动态)详解
今天我们一起来探讨下安卓中BroadcastReceiver组件以及详细分析下它的两种注册方式. BroadcastReceiver也就是"广播接收者"的意思,顾名思义,它就是用来 ...
- Android中BroadcastReceiver广播
BroadCastReceiver 简介 广播接收者( BroadcastReceiver )用于接收广播 Intent ,广播 Intent 的发送是通过调用 Context.sendBroadca ...
- Android中BroadcastReceiver组件具体解释
Android系统的4个组件最终还剩一种组件了BroadcastReceiver,这个组件是全局监听器,能够监听系统全局的广播消息,能够方便的实现系统中不同组件之间的通信 BroadcastRecei ...
- android中broadcastreceiver的用法-代码中注册
界面如下: 问题1:点击“解绑广播接收器“后再次点击”解绑广播接收器“后,程序崩溃,log信息如下: 08-04 05:04:35.420: E/AndroidRuntime(5521): F ...
- android中broadcastreceiver的用法-manifest中注册。
package com.jinhoward.broadcast.activity; import com.jinhoward.broadcast.activity.R; import android. ...
- (转)Android 中LocalBroadcastManager的使用方式
发表于2个月前(2014-11-03 22:05) 阅读(37) | 评论(0) 0人收藏此文章, 我要收藏 赞0 1月10日 #长沙# OSC 源创会第32期开始报名 摘要 android中广播 ...
- Android 中的BroadCastReceiver
BroadCastReceiver 简介 (末尾有源码) BroadCastReceiver 源码位于: framework/base/core/java/android.content.Broadc ...
- Android笔记(二十六) Android中的广播——BroadcastReceiver
为了方便进行系统级别的消息通知,Android有一套类似广播的消息机制,每个应用程序都可以对自己感兴趣的广播进行注册,这样该程序就只会接收自己所关心的广播内容,这些广播可能是来自于系统,也可能是来自于 ...
- Android中创建一个BroadcastReceiver
首先创建一个java类继承BroadcastReceiver类 package com.example.service; import android.content.BroadcastReceive ...
随机推荐
- django 2 ORM操作 ORM进阶 cookie和session 中间件
ORM操作 ORM概念 对象关系映射(Object Relational Mapping,简称ORM)模式是一种为了解决面向对象与关系数据库存在的互不匹配的现象的技术. 简单的说,ORM是通过使用描述 ...
- Django之model.form创建select标签
前言 之前我们学习了form表单验证用户输入格式和自动创建HTML,那么如果用户创建select标签时怎么办呢,先来看下这个东西: models.py 数据格式: class UserInfo(mod ...
- Delphi下Treeview控件基于节点编号的访问
有时我们需要保存和重建treeview控件,本文提供一种方法,通过以树结构节点的编号访问树结构,该控件主要提供的方法如下: function GetGlobeNumCode(inNode:T ...
- LNMP一键环境安装多PHP版本共存的方法
多PHP版本只支持LNMP模式,LNMPA.LAMP模式下不支持!要使用多PHP先安装多PHP版本,在lnmp1.4源码(lnmp1.3的不行哦)目录下运行:./install.sh mphp 按提示 ...
- iOS-AVPlayer使用
1引入AVFoundation.framework框架 2引入头文件<AVFoundation/AVFoundation.h>,并拖入需要播放的视频文件 代码如下: 自定义播放的View, ...
- 【c# 学习笔记】接口与抽象类
抽象类经常与接口一起使用,共同服务于面向对象的编程,这里简单地分析一下接口与抽象类的区别,如下: 1.抽象类使用abstract关键字进行定义,而接口使用interface进行定义:它们都不能进行实例 ...
- Mac下用apache搭建一个局域网服务器
一:由于MacOX系统下自带Apache环境,所以我们在Mac系统下用Apache配置. Mac系统:10.14.4 二:启动Apache 启动 在终端输入:sudo apachectl start验 ...
- 学习JavaScript之this,call,apply(转)
转自: http://www.h5cn.com/js/jishu/2016/0128/17884.html 在之前的JavaScript学习中,this,call,apply总是让我感到迷惑,但是他们 ...
- v-bind 绑定属性
与mustache相区别,他是对内容(content内部)进行修改的.v-bind的语法糖写法是 : v-bind 动态绑定class属性:v-bind:class="对象名" ...
- Nachos java版学习(二)
threads.Lock类 提 供 了 锁 以 保 证 互 斥. 在 临 界 代 码 区 的 两 端 执 行 Lock.acquire()和Lock.release()即可保证同时只有一个线程访问临界 ...