标签:
英文原文:http://developer.android.com/guide/topics/manifest/activity-alias-element.html
采集(更新)日期:2014-6-26
搬迁自原博客:http://blog.sina.com.cn/s/blog_48d491300100zmg5.html
<activity-aliasandroid: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>
targetActivity
属性命名的 Activity 指定别名。
目标 Activity 必须位于当前应用程序中,且必须已在 manifest 中声明。
别名将目标 Activity 表示为另一个独立的实体。
该实体可以拥有一套自己的 Intent 过滤器,而不使用目标 Activity 已有的过滤器。
这些过滤器可以决定哪些 Intent 能通过别名来激活目标 Activity,并且决定系统如何处理别名。
例如:别名内的 Intent 过滤器可以设定“
android.intent.action.MAIN
”和“android.intent.category.LAUNCHER
”
标志,使之能被程序启动器识别,即使目标 Activity 没有过滤器设置了这两个标志也没关系。
除 targetActivity
外,<activity-alias>
的属性就是
<activity>
属性的子集。
对于该子集中已有的属性,目标 Activity 中的设置值不会覆盖别名里的值。
对于子集中没有的属性,则目标 Activity 中的设置值同时适用于别名。
android:enabled
true
”表示可以,“false
”表示不可以。
默认值是“true
”。
<application>
元素拥有自己的 enabled
属性,
它适用于应用程序内的所有组件,包括 Activity 别名。
系统要能够用别名实例化目标 Activity ,
<application>
和<activity-alias>
的这两个属性必须同时设为“true
”。
只要其中有一个是“false
”,别名就不会生效。
android:exported
true
”表示可以,“false
”表示不可以。
如果设为“false
”,则只有当前或用户ID相同的应用程序的组件才能通过别名来启动目标 Activity。
默认值取决于别名是否包含 Intent 过滤器。
不包含任何 Intent 过滤器意味着必须指定精确的别名名称才能启动 Activity 。
这表示别名仅供程序内部使用(因为其他程序不知道它的完整名称)— 这时默认值是“false
”。
反之,只要有一个以上过滤器存在,就意味着别名可以被外部程序使用 — 这时的默认值是“true
”。
android:icon
<activity>
元素的icon
属性。
android:label
<activity>
元素的label
属性。
android:name
android:permission
startActivity()
或
startActivityForResult()
的调用者没有被授权,则目标 Activity 不会被启动。
本属性将取代目标 Activity 本身的权限。 如果本属性未设置,表示不需要授权即能通过别名启动目标 Activity。
有关权限的详细信息,请参阅介绍一文中的 权限 章节。
android:targetActivity
<activity>
元素的 name
属性相一致。
<activity>
Android开发-API指南-<activity-alias>
标签:
原文地址:http://www.cnblogs.com/popapa/p/android_activity-alias-element.html