Orest
Orest

Reputation: 1897

Two launcher activities

I have two activities marked with intent filter

<manifest xmlns:android="http://schemas.android.com/apk/res/android"
package="com.package"
android:versionCode="1"
android:versionName="1.0" >

<uses-sdk android:minSdkVersion="7" />

<application
    android:name=".MyApp"
    android:icon="@drawable/ic_launcher"
    android:label="@string/app_name" >

    <!-- work order activity -->
    <activity
        android:name=".app.WorkOrderActivity"
        android:label="@string/work_order"
        android:taskAffinity="com.package.task_for_work_order_activity" >
        <intent-filter>
            <action android:name="android.intent.action.MAIN" />

            <category android:name="android.intent.category.LAUNCHER" />
        </intent-filter>
    </activity>

    <!-- inventory activity -->
    <activity
        android:name=".app.InventoryActivity"
        android:label="@string/inventory"
        android:taskAffinity="com.package.task_for_inventory_activity" >
        <intent-filter>
            <action android:name="android.intent.action.MAIN" />

            <category android:name="android.intent.category.LAUNCHER" />
        </intent-filter>
    </activity>
</application>

The problem is, that when I'm installing apk file, there is no activity shown, because, as I understood system can't specify what activity should be shown.

I just really need two activities shown in launcher, so please don't give advice about removing intent-filters from second activity, or if you do so provide me another way to show two icons in launcher.

Upvotes: 55

Views: 55002

Answers (5)

Peppe L-G
Peppe L-G

Reputation: 8345

I tested on an emulator running API level 29. The following is enough:

<activity
    android:name=".MyActivity"
    android:label="Activity 1"
    android:exported="true">

    <intent-filter>
        <category android:name="android.intent.category.LAUNCHER" />
        <action android:name="android.intent.action.MAIN" />
    </intent-filter>

</activity>

<activity
    android:name=".MyActivity2"
    android:label="Activity 2"
    android:exported="true">

    <intent-filter>
        <category android:name="android.intent.category.LAUNCHER" />
        <action android:name="android.intent.action.MAIN" />
    </intent-filter>

</activity>

The reason some say this doesn't work is because if the app is already running, it will resume running the last activity in the app no matter which of your 2 activities on the launcher you click on. But try (force) stopping the app, and then you will see the activity corresponding to the one you click on in the launcher starts.

This behavior is usually not what we want, so we can start running the activities in different tasks by using <activity android:taskAffinity="an.identifier.for.the.task">, e.g.:

<activity
    android:name=".MyActivity"
    android:label="Activity 1"
    android:exported="true"
    android:taskAffinity=".task.sellers">

    <intent-filter>
        <category android:name="android.intent.category.LAUNCHER" />
        <action android:name="android.intent.action.MAIN" />
    </intent-filter>

</activity>

<activity
    android:name=".MyActivity2"
    android:label="Activity 2"
    android:exported="true"
    android:taskAffinity=".task.buyers">

    <intent-filter>
        <category android:name="android.intent.category.LAUNCHER" />
        <action android:name="android.intent.action.MAIN" />
    </intent-filter>

</activity>

Upvotes: 3

Mark Gj&#248;l
Mark Gj&#248;l

Reputation: 1882

You need to specify which activity is the default one by adding the following line to your intent-filter:

<category android:name="android.intent.category.DEFAULT"/>

Insert this in the default activity and keep the rest. Then it should work.

You may also want to add a different icon to your 2nd activity with the attribute android:icon="@drawable/myothericon"

Upvotes: 91

a.ch.
a.ch.

Reputation: 8390

Add <action> items with android:name attributes defined to both intent filters:

<application
    android:name=".MyApp"
    android:icon="@drawable/ic_launcher"
    android:label="@string/app_name" >

    <!-- work order activity -->
    <activity
        android:name=".app.WorkOrderActivity"
        android:label="@string/work_order"
        android:taskAffinity="com.package.task_for_work_order_activity" >
        <intent-filter>
            <action android:name="android.intent.action.MAIN" />
            <action android:name=".app.WorkOrderActivity"/>
            <category android:name="android.intent.category.LAUNCHER" />
        </intent-filter>
    </activity>

    <!-- inventory activity -->
    <activity
        android:name=".app.InventoryActivity"
        android:label="@string/inventory"
        android:taskAffinity="com.package.task_for_inventory_activity" >
        <intent-filter>
            <action android:name="android.intent.action.MAIN" />
            <action android:name=".app.InventoryActivity"/>
            <category android:name="android.intent.category.LAUNCHER" />
        </intent-filter>
    </activity>
</application>

Upvotes: 4

Ruddles
Ruddles

Reputation: 303

Seems it is possible to have multiple startup activities by using the task affinity property. See the answer at https://stackoverflow.com/a/3270422/819904

Upvotes: 3

Reno
Reno

Reputation: 33792

I think it's because of the "android.intent.action.MAIN" action, this worked for me :

<application>
    <activity android:name=".MyActivityA" android:icon="@drawable/aicon"  android:label="@string/app_name">
        <intent-filter>
            <category android:name="android.intent.category.LAUNCHER" />
        </intent-filter>
    </activity>
    <activity android:name=".MyActivityB" android:icon="@drawable/bicon" android:label="@string/app_name">
        <intent-filter>
            <category android:name="android.intent.category.LAUNCHER" />
        </intent-filter>
    </activity>
 </application>

Upvotes: 3

Related Questions