Как запустить существующий экземпляр действия, когда он запускается из статического ярлыка

У меня есть Activity(MainActivity) в моем приложении и один статический ярлык (указывает на TempActivity).

Поскольку статические ярлыки всегда будут иметь FLAG_ACTIVITY_NEW_TASK и FLAG_ACTIVITY_CLEAR_TASK, я создал TempActivity, который является невидимым действием, т.е. он запускает MainActivity и затем вызывает finish(). А также, как указано в документации для разработчиков, SecondActivity имеет android:taskAffinity="" в файле приложения AndroidManifest.xml.

MainActivity имеет android:launchMode="singleTop"

Даже после этого MainActivity запускается в новой задаче вместо существующей (создается при запуске с домашнего экрана).

AndroidManifest.xml

<activity
            android:name=".MainActivity"
            android:launchMode="singleTop">
            <intent-filter>
                <action android:name="android.intent.action.MAIN" />

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

            <meta-data
                android:name="android.app.shortcuts"
                android:resource="@xml/shortcuts" />
        </activity>
        <activity android:name=".TempActivity" android:taskAffinity=""></activity>

кратчайший путь

<shortcut
        android:enabled="true"
        android:icon="@drawable/icon"
        android:shortcutDisabledMessage="@string/app_name"
        android:shortcutId="static"
        android:shortcutLongLabel="@string/app_name"
        android:shortcutShortLabel="@string/app_name">
    <intent
        android:action="custom"
        android:targetClass="com.example.mobile.appshortcut.TempActivity"
        android:targetPackage="com.example.mobile.appshortcut" />
    </shortcut>

TempActivity.java

public class TempActivity extends AppCompatActivity {

protected void onCreate(Bundle savedInstanceState) {
    super.onCreate(savedInstanceState);
    //setContentView(R.layout.activity_main2);
    //Intent intent = getIntent(); // From Shortcut
    Intent intent = new Intent(); // For Testing
    intent.setClass(this,MainActivity.class);
    startActivity(intent);
    finish();
}

@Override
protected void onNewIntent(Intent intent) {
    super.onNewIntent(intent);
}

}

Ссылка на документы для разработчиков https://developer.android.com/reference/android/content/pm/ShortcutManager.html

2 ответа

Решение

android:taskAffinity="" должен быть на MainActivityне TempActivity,

Итак, ваш AndroidManifest должен быть примерно таким:

    <activity
        android:launchMode="singleTask"
        android:taskAffinity=""
        android:name=".MainActivity">
        <intent-filter>
            <action android:name="android.intent.action.MAIN"/>

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

        <meta-data
            android:name="android.app.shortcuts"
            android:resource="@xml/shortcut"/>
    </activity>
    <activity
        android:name=".TempActivity"/>

И TempActivity

public class TempActivity extends AppCompatActivity {

    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        startActivity(new Intent(this, MainActivity.class));
        finish();
    }

}

И просто чтобы убедиться, публикуя мой shortcut.xml

<shortcuts xmlns:android="http://schemas.android.com/apk/res/android">
    <shortcut
        android:enabled="true"
        android:shortcutDisabledMessage="@string/app_name"
        android:shortcutId="compose"
        android:shortcutLongLabel="@string/app_name"
        android:shortcutShortLabel="@string/app_name">
        <intent
            android:action="android.intent.action.VIEW"
            android:targetClass="kidinov.org.test.TempActivity"
            android:targetPackage="kidinov.org.test"/>
        <categories android:name="android.shortcut.conversation"/>
    </shortcut>
</shortcuts>

Я создал пример проекта - он отлично работает. Не стесняйтесь проверить это.

Предположительно вы используете FLAG_ACTIVITY_NEW_TASK потому что вы хотите чистую, новую версию действия при запуске из этого ярлыка.

Вы можете переключить режим запуска MainActivity на singleInstance, Тогда у вас есть возможность использования onStart/onRestart или же onNewIntent(Intent) очистить (и сбросить активность и взлом TempActivity больше не потребуется).

@Override
protected void onNewIntent(Intent intent) {
    super.onNewIntent(intent);
    if (intent.getAction().equals("custom")) {
        //reset
    }
}
Другие вопросы по тегам