Android:BroadcastReceiver
- 动态广播
- 在代码中注册receiver
- 一定要手动在onDestroy()时调用unregisterReveiver()来取消注册
- 静态广播
- 在AndroidManifest.xml中注册receiver(主要是设定action)
public class MainActivity extends Activity {
private NetworkChangeReceiver receiver;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
IntentFilter intentFilter = new IntentFilter();
intentFilter.addAction("android.net.conn.CONNECTIVITY_CHANGE");
receiver = new NetworkChangeReceiver();
registerReceiver(receiver, intentFilter);
}
@Override
protected void onDestroy() {
unregisterReceiver(receiver);//remember to unregister manually
super.onDestroy();
}
}
2. 定义receiver的行为:继承BroadcastReceiver并在覆写onReceiver()时定义好接收到广播时处理的逻辑:
public class NetworkChangeReceiver extends BroadcastReceiver {
@Override
public void onReceive(Context context, Intent intent) {
ConnectivityManager manager = (ConnectivityManager) context.getSystemService(Context.CONNECTIVITY_SERVICE);
NetworkInfo networkInfo = manager.getActiveNetworkInfo();
if(networkInfo != null && networkInfo.isAvailable())
Toast.makeText(context, "Network is available.", Toast.LENGTH_SHORT).show();
else
Toast.makeText(context, "Network is unavailable.", Toast.LENGTH_SHORT).show();
}
}
3. 在AndroidManifest.xml中定义必要的权限,主要<uses-permission>标签位于<manifest>的下一级,即与<application>同级:
<uses-permission android:name="android.permission.ACCESS_NETWORK_STATE"/>
public class BootCompleteReceiver extends BroadcastReceiver {
@Override
public void onReceive(Context context, Intent intent) {
Toast.makeText(context, "Boot complete.", Toast.LENGTH_LONG).show();
}
}
2. 在AndroidManifest.xml中定义receiver(与<activity>同级,<application>的子元素):
<receiver android:name=".MyBroadcast">
<intent-filter android:priority="100">
<action android:name="com.scv.lawrence.MY_BROADCAST"/>
</intent-filter>
</receiver>
3. 在AndroidManifest.xml中添加相应权限(<application>同级,<manifest>的子元素):
<uses-permission android:name="android.permission.RECEIVE_BOOT_COMPLETED"/>
- 标准(Normal broadcast)
- 默认的广播方式,即broadcast发出后,所有receiver几乎在同时接收到。
- 有序(Ordered broadcast)
- receiver根据设定的优先级(priority)来决定broadcast的传递顺序,较高优先级的receiver可以选择拦截该broadcast阻止其向后传播
- 二者区别
- 发送广播时,标准广播调用的是sendBroadcast(),有序广播调用的是sendOrderedBroadcast()
- 接收广播时(在AndroidManifest.xml中注册receiver),标准广播不用在<intent-filter>中设置android:priority属性,有序广播则需要设定一个整数,数值越大priority越高
在代码中发送自定义的标准/无序广播:
Button sendBroadcast = (Button) findViewById(R.id.broadcast);
sendBroadcast.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View v) {
Intent intent = new Intent("com.scv.lawrence.MY_BROADCAST");
sendBroadcast(intent);
// sendOrderedBroadcast(intent, null);
}
});
在AndroidManifest.xml中定义(父元素为<application>,即与<activity>同级):
<receiver android:name=".MyBroadcast">
<intent-filter android:priority="100">
<action android:name="com.scv.lawrence.MY_BROADCAST"/>
</intent-filter>
</receiver>
- 全局广播
- 非LocalBroadcastManager进行发送或接收的广播即为全局广播
- 本地广播
- 发送/接收的broadcast只限于当前app范围内,安全性比全局高
- 与全局广播的区别在于本地广播依靠LocalBroadcastManager进行注册、发送及注销receiver
public class LocalBroadcastReceiver extends BroadcastReceiver {
@Override
public void onReceive(Context context, Intent intent) {
Toast.makeText(context, "Get the local broadcast.", Toast.LENGTH_SHORT).show();
}
}
2. 和动态广播差不多,区别主要在使用LocalBroadcastManager的实例来进行操作:
public class MainActivity extends Activity {
private LocalBroadcastManager localBroadcastManager;
private LocalBroadcastReceiver localReceiver;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
//Local Broadcast
localBroadcastManager = LocalBroadcastManager.getInstance(MainActivity.this);
final Button localBroadcast = (Button) findViewById(R.id.local_broadcast);
localBroadcast.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View v) {
Intent intent = new Intent("com.scv.lawrence.LOCAL_BROADCAST");
localBroadcastManager.sendBroadcast(intent);
}
});
IntentFilter localIntentFilter = new IntentFilter();
localIntentFilter.addAction("com.scv.lawrence.LOCAL_BROADCAST");
localReceiver = new LocalBroadcastReceiver();
localBroadcastManager.registerReceiver(localReceiver, localIntentFilter);
}
@Override
protected void onDestroy() {
localBroadcastManager.unregisterReceiver(localReceiver);
super.onDestroy();
}
}
3. 在AndroidManifest.xml中配置permission. (如有必要)
Android:BroadcastReceiver的更多相关文章
- Android四大组件之一:BroadCastReceiver(广播接收者)
广播接受者是(BroadCastReceiver)是Android中的地大组件之一,之前学习了一些关于BroadCastReceiver方面的知识,今天回过头来发现已经快忘记的差不多了,毕竟现在是刚开 ...
- Android(java)学习笔记177:BroadcastReceiver之 应用程序安装和卸载 的广播接收者
国内的主流网络公司(比如网易.腾讯.百度等等),他们往往采用数据挖掘技术获取用户使用信息,从而采用靶向营销.比如电脑上,我们浏览网页的时候,往往会发现网页上会出现我们之前经常浏览内容的商 ...
- Android(java)学习笔记176:BroadcastReceiver之 短信发送的广播接收者
有时候,我们需要开发出来一个短信监听器,监听用户发送的短信记录,下面就是一个案例,这里同样需要使用广播机制. 下面同样是代码示例,MainActivity.java 和 activity_main. ...
- Android(java)学习笔记175:BroadcastReceiver之 外拨电话的广播接收者
首先我们示例工程一览表如下: 1.首先我们还是买一个收音机,定义一个OutCallReceiver继承自BroadcastReceiver,onReceive()方法中定义了监听到广播,要执行的操作: ...
- Android(java)学习笔记173:BroadcastReceiver之 静态注册 和 动态注册
1. 广播接受者>什么是广播.收音机.电台:对外发送信号.收音机:接收电台的信号. >在android系统里面,系统有很多重要的事件: 电池电量低,插入充电器,sd卡被移除,有电话打出去, ...
- Android(java)学习笔记179:BroadcastReceiver之 有序广播和无序广播(BroadcastReceiver优先级)
之前我们在Android(java)学习笔记178中自定义的广播是无序广播,下面我们要了解一下有序广播: 1. 我们首先了解一下有序广播和无序广播区别和联系? (1) 有序广播> 接受者 ...
- Android(java)学习笔记178:BroadcastReceiver之 自定义广播
广播使用: 电台:对外发送信号.---------电台发送广播(可以自定义) 收音机:接收电台的信号.-----广播接收者 这里,我们就说明自定 ...
- Android(java)学习笔记122:BroadcastReceiver之 有序广播和无序广播(BroadcastReceiver优先级)
之前我们在Android(java)学习笔记178中自定义的广播是无序广播,下面我们要了解一下有序广播: 1. 我们首先了解一下有序广播和无序广播区别和联系? (1)有序广播> 接受者有优先级, ...
- Android(java)学习笔记121:BroadcastReceiver之 自定义广播
广播使用: 电台:对外发送信号.---------电台发送广播(可以自定义) 收音机:接收电台的信号.-----广播接收者 这里,我们就说明自定 ...
随机推荐
- erwin逆向工程,logical模型列名修改为中文
逆向工程,应该选择physical template,这样拷贝到logical/physical 模型中,才可以将logical模型的列名修改为中文.
- 【网络结构】GoogLeNet inception-v1:Going deeper with convolutions论文笔记
目录 0. 论文链接 1. 概述 2. inception 3. GoogleNet 参考链接 @ 0. 论文链接 1. 概述 GoogLeNet是谷歌团队提出的一种大体保持计算资源不变的前提下, ...
- geoserver源码学习与扩展——restAPI访问
产生这篇文章的想法是在前端通过js调用restAPI时,总是不成功,发送ajax请求时还总是出现类似跨域的问题,后来查找才发现,默认情况下restAPI的访问都需要管理员权限,而通过ajax请求传输用 ...
- 理解多线程管理类 CWorkQueue
有些人会觉得多线程无非是,有多少任务就启动多少线程,CreadThread,执行完了自己结束就释放资源了,其实不然.多线程是需要管理的,线程的启动.执行.等待和结束都需要管理,线程间如何通信,如何共享 ...
- git拉取GitLab工程报错Repository not found
# git clone http://xxx/jiqing/frog.git 正克隆到 'frog'... fatal: repository 'http://xxx/jiqing/frog.git/ ...
- Java里\r \n \t
\t 相当于tab,缩进 \n 回车 \r 换行 使用来格式化输出的,如:System.out.printf("11111\t2222222");上面的输出的效果就是在11111与 ...
- 5分钟弄懂Docker
尽管之前久闻Docker的大名了,但是天资愚钝,对其到底是个啥东西一直摸不清,最近花了一段时间整理了一下,算是整理出一点头绪来. 官网的介绍是这样的: Docker is an open platfo ...
- dva-loading使用方法
1. 下载dva-loading npm install dva-loading --save 2. 导入并使用dva-loading import createLoading from 'dva-l ...
- Tracing on Linux
The Linux tracing APIs are a relatively new addition to the kernel and one of the most powerful new ...
- canvas线性变换、颜色和样式选择
1.应用不同的线型 ctx.lineWidth = value; 线条的宽度,默认为1 ctx.lineCap = type; 设置端点样式, type默认为butt,可选值round,square, ...