如何从静态快捷方式启动 activity 的现有实例

How to launch existing instance of an activity from static shortcut

我的应用程序中有一个 Activity(MainActivity) 并且有一个静态快捷方式(指向 TempActivity)。

由于静态快捷方式将始终设置 FLAG_ACTIVITY_NEW_TASK 和 FLAG_ACTIVITY_CLEAR_TASK,我创建了 TempActivity 这是一个不可见的 Activity 即它将启动 Main Activity 然后调用 finish()。并且正如开发人员文档中所建议的那样,SecondActivity 在应用程序的 AndroidManifest.xml 文件中具有 android:taskAffinity=""

主要Activity有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);
}

}

Link 到开发者文档 https://developer.android.com/reference/android/content/pm/ShortcutManager.html

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>

我创建了 sample project - 它运行良好。请随时查看。

假设您正在使用 FLAG_ACTIVITY_NEW_TASK,因为您想要一个干净的新版本 activity 从该快捷方式启动时。

您可以将 MainActivity 启动模式切换为 singleInstance。然后你可以选择使用 onStart/onRestartonNewIntent(Intent) 来清除(并重置 activity 并且不再需要 TempActivity hack)。

@Override
protected void onNewIntent(Intent intent) {
    super.onNewIntent(intent);
    if (intent.getAction().equals("custom")) {
        //reset
    }
}