activity-alias属性是用于在AndroidManifest.xml文件中指定一个别名(alias)来代替一个已经存在的活动(activity)组件的属性。它的使用可以用于以下几种情况:
示例:
<activity-alias
android:name=".MainActivityAlias"
android:targetActivity=".MainActivity" >
<intent-filter>
<action android:name="android.intent.action.MAIN" />
<category android:name="android.intent.category.LAUNCHER" />
</intent-filter>
</activity-alias>
示例:
<activity
android:name=".MainActivity"
android:label="@string/app_name" >
<intent-filter>
<action android:name="android.intent.action.MAIN" />
<category android:name="android.intent.category.LAUNCHER" />
</intent-filter>
</activity>
<activity-alias
android:name=".MainActivityAlias"
android:targetActivity=".MainActivity" >
<intent-filter>
<action android:name="android.intent.action.VIEW" />
<category android:name="android.intent.category.DEFAULT" />
<category android:name="android.intent.category.BROWSABLE" />
<data android:scheme="http" />
</intent-filter>
</activity-alias>
在上面的例子中,当通过浏览器打开一个http链接时,系统会匹配到MainActivityAlias,并启动MainActivity。
需要注意的是,activity-alias只是一个别名,它本身并不是一个活动组件,所以它没有自己的生命周期,也不能接收自己的Intent。它只是一个代理,通过intent-filter转发到targetActivity所指定的活动组件。