<activity-alias android:enabled=["true" | "false"]
android:exported=["true" | "false"]
android:icon="drawable resource"
android:label="string resource"
android:name="string"
android:permission="string"
android:targetActivity="string" >
. . .
</activity-alias>
<application>
<intent-filter>
<meta-data>
Activity的别名,由元素的targetActivity属性命名。作为别名,它和target activity必须在相同的应用中,而且在manifest文件中target activity必须在别名之前就被声明。
这个别名意味着这个target activity会作为独立的实体。它有它自己的一套intent filters,而不是target activity自身的intent filters,通过这个别名这些intent filters决定那些intents能激活这个target以及系统会如何处理这个别名。例如,在这个别名中的intent filter可以指定“android.intent.action.MAIN”和“android.intent.category.LAUNCHER”标记,这就会导致即使在这个target activity自身也设置了这些标记,而在应用启动时却激活的是这个别名。
除了targetActivity,<activity-alias>属性是<activity>属性的子集。对于子集内的属性来说,对这个target activity没有设置的值会被转嫁到别名上。然而,对于没有在子集内的属性来说,对这个target activity设置的值也会应用到别名。
android:enabled
是否这个target activity能被系统通过这个别名初始化,若能则为true,否则为false。默认值是“true”。
<application>元素有它自身的enabled属性,这个属性将被应用到所有的应用组件,包括activity别名。如果系统要通过别名初始化这个target activity,那么<application>和<activity-alias>属性都必须为“true”。如果有一个为false,那么这个别名就不会工作。
android:exported
是否其它应用的组件能通过这个别名启动这个target activity,若能则为true,否则为false。若为“false”,则这个target activity只能通过同一个应用的组件或具有相同用户ID的applications启动。
默认值依赖于是否别名包含过滤器。过滤器的缺乏意味着这个activity只能通过由这个别名的精确名称指定的别名调用。这意味着这个别名只能在应用内部被调用(因为其他应用不知道别名的名称)-因此默认值为false。另一方面,至少存在一个过滤器意味着这个别名可以在外部被调用-因此默认值为true。
android:icon
通过别名呈现给用户时这个target activity的图标。查看<activity>元素的icon属性可以获取更多相关信息。
android:label
通过别名呈现给用户时这个让用户可读的别名的名称。更多信息参见<activity>元素的label属性。
android:name
这个别名的唯一的名称。这个名称类似于完整的类名。然而,和target activity的名称不同的是,这个别名可以是任意的;它不引用实实在在的类。
android:permission
客户端通过别名启动target activity或处理某些操作时的权限的名称。如果没有为startActivity()或startActivityForResult()的调用者授予特定的权限,那么这个target activity就不会被激活。
这个属性可以替换target activity自身的一切权限设置。如果没有设置,那么通过这个别名激活target activity时就不需要权限。
android:targetActivity
能通过别名激活的activity的名称。这个名称必须匹配<activity>元素的name属性,在manifest文件中这个<activity>位于别名之前。
API Level 1