Android开发-API指南-<receiver>

<receiver>

英文原文:http://developer.android.com/guide/topics/manifest/receiver-element.html
采集(更新)日期:2014-7-2
搬迁自原博客:http://blog.sina.com.cn/s/blog_48d491300100zmv7.html

语法:

<receiver android:enabled=["true" | "false"]
          android:exported=["true" | "false"]
          android:icon="drawable resource"
          android:label="string resource"
          android:name="string"
          android:permission="string"
          android:process="string" >
    . . .
</receiver>

包含于:
<application>
可包含:
<intent-filter>
<meta-data>
说明:
声明一个广播接收器(
BroadcastReceiver
的子类),并成为应用程序的一个组件。
广播接收器使得应用程序能接收由系统或其他应用程序广播的 Intent,即使本应用程序的其他组件都没有运行也没关系。

向系统声明广播接收器的方式有两种:
一种是在 Manifest 文件中以本元素声明,
另一种是用代码动态创建接收器并用
Context.registerReceiver()
方法注册。
关于动态创建广播接收器的更多信息,请参阅
BroadcastReceiver
类的说明。

属性:
android:enabled
广播接收器是否能被系统实例化 — “true”可以,“false”不可以。
默认值是“true”。

<application>
元素拥有自己的
enabled
属性,适用于应用程序的所有组件,包括广播接收器。
为了启用广播接收器,
<application>
<receiver> 的本属性都必须设置为“true”。
只要其中任何一个为“false”,则广播接收器就将被禁用,它将不能被实例化。

android:exported
广播接收器能否接收来自应用程序之外的消息 — “true”可接收,“false”不接收。
如果设为“false”,则本接收器只能接收本应用程序或用户 ID 相同程序的组件所发出的消息。

默认值依赖于广播接收器是否包含 Intent 过滤器。
如果不含任何过滤器,则意味着只能通过指定精确类名的 Intent 对象来触发。
这表示该接收器仅供应用程序内部使用(因为其他程序通常不知道精确的类名称)。这时缺省值是“false”。
另一方面,如果存在一个以上的过滤器,则表示广播接收器愿意接收来自系统或其他应用程序的 Intent,因此默认值是“true”。

本属性并不是限制广播接收器对外公开程度的唯一途径。
还可以利用权限来对可发送消息的外部对象进行限制(请参阅permission属性)。

android:icon
代表广播接收器的图标。
本属性必须设为对 drawable 资源的引用,该资源包含了图片的定义。
如果未设置本属性值,则将使用全局性的应用程序图标来代替。(参阅
<application>
元素的
icon
属性)。

广播接收器的图标 — 不管是在本属性还是在
<application>
元素中设置的 — 同时也是接收器中所有 Intent 过滤器的默认图标(参阅
<intent-filter>
元素的
icon
属性)。

android:label
供用户阅读的广播接收器的文本标签。
如果未设置本属性,则用全局性的应用程序文本标签代替(参阅
<application>
元素的
label
属性)。

广播接收器的文本标签 — 不管是在本属性还是在
<application>
元素中设置的 — 同时也是接收器中所有 Intent 过滤器的默认文本标签(参阅
<application>
元素的
label属性)。

本文本标签应该设为对字符串资源的引用,这样就能像用户界面中的其他字符串一样对其进行本地化。
不过为了应用程序开发时的便利,也可以直接设置为字符串。

android:name
实现广播接收器的类的名称,即
BroadcastReceiver
的子类。
这应该是一个完全限定格式的类名(比如“com.example.project.ReportReceiver”)。
不过作为简称,如果首字符为句点(比如“. ReportReceiver”,则会自动在前面加上
<manifest>
元素指定的包名称。

应用程序一经发布,就
不应更改本名称
(除非设置了android:exported="false")。

没有默认值。本名称必须指定。

android:permission
发送方要发送消息给广播接收器所必需的权限名称。
如果本属性未被设置,则
<application>
元素的
permission
属性所设置的权限将应用于广播接收器。
如果以上两个属性都未设置,则本接收器将不受权限机制的保护。

关于权限的详细信息,请参阅 Manifest 介绍一文的
Permissions
部分和另一篇文档安全和权限

android:process
运行广播接收器的进程名称。
通常,应用程序的所有组件都运行在创建时的默认进程中。
该进程的名称与程序包名相同。
<application>
元素的
process
属性可以为每个组件设置不同的默认进程。
但每个组件也可以用各自的 process 属性覆盖该默认值,使得程序可以跨越多个进程运行。

如果本属性值的名称以冒号(‘:‘)开头,则必要时会新建一个属于该程序私有的进程,广播接收器将运行于该新进程中。
如果进程名称以小写字母开头,则广播接收器将运行于一个以此名字命名的全局进程中,并赋予相应的访问权限。
这就允许不同应用程序的多个组件共享同一个进程,以减少资源的占用。

引入自:
API 级别 1
时间: 2024-10-05 05:00:44

Android开发-API指南-<receiver>的相关文章

Android开发-API指南-&lt;application&gt;

<application> 英文原文:http://developer.android.com/guide/topics/manifest/application-element.html 采集(更新)日期:2014-5-30 更新下老的文档,祝贺下自己 42 岁的生日. 搬迁自原博客:http://blog.sina.com.cn/s/blog_48d491300100zmga.html 语法: <application android:allowTaskReparenting=[&q

Android开发-API指南-&lt;provider&gt;

<provider> 英文原文:http://developer.android.com/guide/topics/manifest/provider-element.html 采集(更新)日期:2014-7-1 搬迁自原博客:http://blog.sina.com.cn/s/blog_48d491300100zmv5.html 语法: <provider android:authorities="list" android:enabled=["true&

Android开发-API指南-&lt;uses-feature&gt;

<uses-feature> 英文原文:http://developer.android.com/guide/topics/manifest/uses-feature-element.html 采集(更新)日期:2014-7-7 搬迁自原博客:http://blog.sina.com.cn/s/blog_48d491300100zmwf.html 在本文中 Google Play 和基于设备特性的过滤机制 基于显式声明的特性需求进行过滤 基于隐含的特性需求进行过滤 对蓝牙特性的特殊处理 对应用

Android开发-API指南-应用程序开发基础

Application Fundamentals 英文原文:http://developer.android.com/guide/components/fundamentals.html 采集日期:2014-04-16 搬迁自原博客:http://blog.sina.com.cn/s/blog_48d491300101h41p.html 在本文中 应用程序组件 激活组件 Manifest 文件 声明组件 声明应用程序的需求 应用程序资源 Android 应用程序是用 Java 语言编写的.And

Android开发-API指南-&lt;compatible-screens&gt;

<compatible-screens> 英文原文:http://developer.android.com/guide/topics/manifest/compatible-screens-element.html 采集(更新)日期:2014-6-30 搬迁自原博客:http://blog.sina.com.cn/s/blog_48d491300100zmub.html 语法: <compatible-screens> <screen android:screenSize=

Android开发-API指南-任务和回退栈

Task 和 Back Stack 英文原文: http://developer.android.com/guide/components/tasks-and-back-stack.html 采集(更新)日期:2014-12-16 在本文中 保存 Activity 状态 管理多个 Task 指定启动模式 处理 affinity 清理回退栈k 启动任务 相关文章 Multitasking the Android Way 参阅 Android 设计 : 导航 <activity> manifest

【最后一篇API译文】Android开发-API指南- Contacts Provider

Contacts Provider 今年加入了某字幕组,加之杂事颇多,许久未添新文了,惭愧之极. 在听闻 Google 即将重返中国后,近日忽又发现官方网站正在放出 API 中文版,比如本文.当然不是大家所译,但至少句子结构较通顺,窃以为比 MSDN 中文版好些.虽有些生硬(比如将 Provider 译为“提供者”,有趣得紧),但好在前无古人,也许 Google 自此便统一了自己的中文术语也未可知.能让更多的国人精确领悟 Android 的精髓,肯定是好事,希望 Google 继续坚持. 这事应

Android开发-API指南-服务

Service 英文原文:http://developer.android.com/guide/components/services.html 采集(更新)日期:2014-12-23 原博客:http://blog.sina.com.cn/s/blog_48d49130010102pn.html 在本文中 概述 在manifest中声明服务 创建一个started服务 扩展IntentService类 扩展Service类 启动一个服务 终止一个服务 创建一个bound服务 向用户发送通知 在

Android开发-API指南-&lt;service&gt;

<service> 英文原文:http://developer.android.com/guide/topics/manifest/service-element.html 采集(更新)日期:2014-7-2 搬迁自原博客:http://blog.sina.com.cn/s/blog_48d491300100zmva.html 语法: <service android:enabled=["true" | "false"] android:expor