清单文件——meta-data

语法(SYNTAX):

<meta-dataAndroid:name="string"
           android:resource="resource specification"
           android:value="string"/>

被包含于(CONTAINED IN):

  • <activity>
  • <activity-alias>
  • <service>
  • <receiver>

说明(DESCRIPTION):

这个元素用name-value对的格式给其父组件提供任意可选的数据。一个组件元素能够包含任意多个<meta-data>子元素,所有这些元素中定义的值会被收集到一个Bundle对象中,并且提供给组件的PackageItemInfo.metaData属性字段。

通常值是通过其value属性来指定的。但是,也可以使用resource属性来代替,把一个资源ID跟值进行关联。
例如,下面的代码就是把存储在@string/kangaroo资源中的值跟”zoo”名称进行关联:

<meta-data android:name="zoo" android:value="@string/kangaroo" />

另一个方面,使用resource属性会给zoo分配一个数字资源ID,而不是保存在资源中的值。例如:

<meta-data android:name="zoo" android:resource="@string/kangaroo" />

要避免使用多个独立的<meta-data>实体来提供相关的数据。相反如果有复杂的数据要跟组件关联,那么把数据作为资源来保存,并使用resource属性,把相关的资源ID通知给组件。

属性(ATTRIBUTES):

  • android:name

    针对项目的一个唯一名称。使用Java样式的命名规则,可以确保名称的唯一性,例如:
com.example.project.activity.fred。
  • android:resource

    这个属性定义了一个要引用的资源。资源的ID会跟这个项目进行关联。通过Bundle.getInt()方法能够从meta-data的Bundle对象中获取这个ID。

  • android:value

    这个属性会给这个项目分配一个值。下表列出了可能分配的数据的数据类型,以及获取这些数据的方法:

类型Bundle对象方法
字符串。对于一个Unicode字符,要使用双斜线(\\)来进行转义,如\\n和\\uxxxxgetString()
整数值,如100getInt()
布尔值,true或falsegetBoolean()
颜色值,如#rgb、#argb、#rrggbb、#aarrggbbgetString()
浮点值,如1.23getFloat()

被引入版本(INTRODUCED IN):

API Level 1

Copyright© 2020-2022 li-xyz 冀ICP备2022001112号-1