This content originally appeared on DEV Community and was authored by mikkel septiano
Introduction
Have you ever see some apps can change their app icon without reinstall of update their app from Play Store? We all know that one app can only contains one app icon integrated. So if your app want to integrate with multiple app icon, You can using Activity Alias.
Android’s <activity-alias>
tag is one of the most unused tags in the android manifest. The existence and benefits of it are unknown to many Android developers, even today. This API is introduced from API Level 1.
Activity alias syntax is written as below:
This tag contained in:
<application>
And this tag can contain:
<intent-filter>
<meta-data>
Attribute explanation
android:enabled
Whether or not the target activity can be instantiated by the system through this alias — "true" if it can be, and "false" if not. The default value is "true".
The<application>
element has its own enabled attribute that applies to all application components, including activity aliases. The<application>
and<activity-alias>
attributes must both be "true" for the system to be able to instantiate the target activity through the alias. If either is "false", the alias does not work.android:exported
Whether or not components of other applications can launch the target activity through this alias — "true" if they can, and "false" if not. If "false", the target activity can be launched through the alias only by components of the same application as the alias or applications with the same user ID.
The default value depends on whether the alias contains intent filters. The absence of any filters means that the activity can be invoked through the alias only by specifying the exact name of the alias. This implies that the alias is intended only for application-internal use (since others would not know its name) — so the default value is "false". On the other hand, the presence of at least one filter implies that the alias is intended for external use — so the default value is "true".android:icon
An icon for the target activity when presented to users through the alias. See the<activity>
element's icon attribute for more information.android:label
A user-readable label for the alias when presented to users through the alias. See the<activity>
element's label attribute for more information.android:name
A unique name for the alias. The name should resemble a fully qualified class name. But, unlike the name of the target activity, the alias name is arbitrary; it does not refer to an actual class.android:permission
The name of a permission that clients must have to launch the target activity or get it to do something via the alias. If a caller ofstartActivity()
orstartActivityForResult()
has not been granted the specified permission, the target activity will not be activated.
This attribute supplants any permission set for the target activity itself. If it is not set, a permission is not needed to activate the target through the alias.android:targetActivity
The name of the activity that can be activated through the alias. This name must match the name attribute of an<activity>
element that precedes the alias in the manifest.
Example of writing activity aliases as below:
the targetActivity is Splash Activity because we create fake activity (activity alias) which references to Splash Activity
This content originally appeared on DEV Community and was authored by mikkel septiano
mikkel septiano | Sciencx (2023-03-27T02:17:49+00:00) Create Dynamic App Icon Using Activity Alias. Retrieved from https://www.scien.cx/2023/03/27/create-dynamic-app-icon-using-activity-alias/
Please log in to upload a file.
There are no updates yet.
Click the Upload button above to add an update.