(声明:此文从Android官方文档翻译摘录而来,可能存在翻译错误
)
Manifest 文件介绍:
在APP能够在Android系统运行之前,必须在 AndrodiManifest.xml(“Manifest”文件)中对APP进行配置。
Manifest能够实现的部分功能罗列如下:
- 配置APP的使用权限
- 确定需要的最小支持 API Level
- 确认APP运行需要的硬件支持,比如相机、蓝牙等
- API的 Library
- ... ...
以下是 Manifest 文件的一些常用的功能解析:
- 定义APP组件
Manifest 的优先工作是告知系统,APP运行需要的组件。以下面的 Manifest为例:
<?xml version="1.0" encoding="utf-8"?>在<application> 元素中, android:icon 显示APP的图标;在<activity> 元素中,android:name 表示需要用的 Activiy名称。所有的app组件都必需包含在 Manifest文件中,否则,系统无法识别这些组件,也无法运行这些组件。一个例外是BroadcastReceiver可以在代码中通过系统函数 registerReceiver() 动态获取权限。
<manifest ... >
<application android:icon="@drawable/app_icon.png" ... >
<activity android:name="com.example.project.ExampleActivity"
android:label="@string/example_label" ... >
</activity>
...
</application>
</manifest>
- 定义组件功能
之前提到,可以使用 intent 启动 activities、services和Broadcastreceivers。但是,发出一个 intent 请求可能有多个app能够响应。这种情况出现时,对于APP来说,可以通过配置 intent filter 来确定 app 能够响应的 intent。以下面的配置文档为例:
<manifest ... >当APP通过intent发送 ACTION_SEND 指令到 startActivity() 方法后,就能够启动响应的程序发送 email。
...
<application ... >
<activity android:name="com.example.project.ComposeEmailActivity">
<intent-filter>
<action android:name="android.intent.action.SEND" />
<data android:type="*/*" />
<category android:name="android.intent.category.DEFAULT" />
</intent-filter>
</activity>
</application>
</manifest>
- 定义APP的需求
由于 Android设备很多,功能不一。因此,可以通过这里配置程序运行需要的软件配置需求。,下面是一个配置需求的实例:
<manifest ... >
<uses-feature android:name="android.hardware.camera.any"
android:required="true" />
<uses-sdk android:minSdkVersion="7" android:targetSdkVersion="19" />
...
</manifest>
- 描述 APP 资源