单击通知时如何保留当前返回堆栈(或任务)?

How to preserve current back stack (or task) when notification is clicked?

在我的应用程序中,我创建了一个启动 Details Activity 的通知。我想将此 activity 添加到 当前 任务(或返回堆栈)的顶部。例如,我希望应用程序任务(返回堆栈)的行为如下:

但我明白了:

我没有使用 FLAG_ACTIVITY_CLEAR_TASKFLAG_ACTIVITY_NEW_TASK 标志。我该怎么办?

编辑:第一张图片只是一个例子。我认为问题的标题是完全明确的。我想在当前堆栈顶部添加 Details Activity,而不是从新任务开始。

这就是我创建 PendingIntent:

的方式
    // Details activity intent
    Intent intent = new Intent(context, DetailsActivity.class);
    intent.putExtra(Com.KEY_ID, event.getId());
    PendingIntent pendingIntent = PendingIntent.getActivity(context, 0,
            intent, PendingIntent.FLAG_UPDATE_CURRENT);

这是清单:

    <activity
        android:name=".MainActivity"
        android:label="@string/app_name_system"
        android:launchMode="singleTop"
        android:theme="@style/AppTheme.NoActionBar">

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

    <activity
        android:name=".NoteActivity"
        android:label="@string/app_name_system"
        android:theme="@style/AppTheme.NoActionBar"
        android:windowSoftInputMode="stateHidden" />

    <activity
        android:name=".DetailsActivity"
        android:launchMode="singleTop"
        android:label="@string/app_name_system"
        android:theme="@style/AppTheme.NoActionBar" />

您可以使用 PendingIntent.getActivities 而不是 PendingIntent.getActivity 来构建堆栈。

Intent mainActivityIntent = new Intent(context,MainActivity.class);
mainActivityIntent.addFlags(Intent.FLAG_ACTIVITY_NEW_TASK);

Intent noteActivityIntent= new Intent(context,NoteActivity.class);
noteActivityIntent.addFlags(Intent.FLAG_ACTIVITY_NEW_TASK);

Intent detailActivityIntent= new Intent(context,DetailActivity.class);

final PendingIntent pendingIntent = PendingIntent.getActivities(ctx, UNIQUE_REQUEST_CODE++,
            new Intent[] {mainActivityIntent,noteActivityIntent,detailActivityIntent},PendingIntent.FLAG_UPDATE_CURRENT);

这应该可以解决您的问题。

请参阅此 link 了解更多详情 Back to main activity from notification-created activity

您需要使用 getActivities() 并在接受意图数组的第三个参数中指定整个导航路径。您需要按照您的应用程序导航应该工作的顺序构建该数组,即最左边的是 root/main activity 并从那里进一步向下。

像这样

Intent mainActivityIntent = new Intent(context, MainActivity.class);
mainActivityIntent.addFlags(Intent.FLAG_ACTIVITY_NEW_TASK); // only specify new task flag for MainActivity

Intent noteActivityIntent= new Intent(context,NoteActivity.class);

Intent detailsActivityIntent = new Intent(context, DetailsActivity.class);

PendingIntent pendingIntent = PendingIntent.getActivities(context, 0,
            new Intent[] {mainActivityIntent,noteActivityIntent,detailsActivityIntent},PendingIntent.FLAG_UPDATE_CURRENT);

请注意:如果您的应用程序已经激活,一旦您按返回 android 将带您回到您的 NoteActivity,然后 MainActivity。如果活动已经存在,它将重新启动活动,否则将创建新活动。

我找到了这个 link:Preserving Navigation when Starting an Activity。虽然它没有为我的问题提供确切的解决方案,但它产生了预期的结果。

link 说明我们应该在新任务中开始 DetailsActivity 不同的 affinity

清单:

    <activity
        android:name=".DetailsActivity"
        android:excludeFromRecents="true"
        android:label="@string/app_name_system"
        android:launchMode="singleTop"
        android:taskAffinity=""
        android:theme="@style/AppTheme.NoActionBar" />

PendingIntent创作:

    Intent intent = new Intent(context, DetailsActivity.class);
    intent.putExtra(Com.KEY_ID, event.getId());
    intent.setFlags(Intent.FLAG_ACTIVITY_NEW_TASK | Intent.FLAG_ACTIVITY_CLEAR_TASK);
    PendingIntent pendingIntent = PendingIntent.getActivity(context, 0,
            intent, PendingIntent.FLAG_UPDATE_CURRENT);

我想要完全相反的东西(这是默认行为)。

事实证明设置 noHistory="true" or/and 在通知启动的 Activity 上调用 finish(),保留现有的后台堆栈。

所以基本上解决方案是要么不将 Activity 保留在后台堆栈中,要么创建一个 'NotificationActivity' 将不会保留并将负责启动 Activity 你想要(您的示例中的详细信息Activity)。

android docs 中的解决方案可能适合您。它对我有用,但我只有一个 parent-child 返回堆栈。

与 parent 关系的清单:

<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>

<!-- MainActivity is the parent for NoteActivity-->
<activity
    android:name=".ResultActivity"
    android:parentActivityName=".MainActivity" />
    ...
</activity>

<!-- NoteActivity is the parent for DetailsActivity -->
<activity
    android:name=".DetailsActivity "
    android:parentActivityName=".NoteActivity " />
    ...
</activity>

正在创建待定意向:

// Create an Intent for the activity you want to start
Intent resultIntent = new Intent(this, DetailsActivity.class);

// Create the TaskStackBuilder and add the intent, which inflates the back stack
TaskStackBuilder stackBuilder = TaskStackBuilder.create(this);
stackBuilder.addNextIntentWithParentStack(resultIntent);

// Get the PendingIntent containing the entire back stack
PendingIntent resultPendingIntent = stackBuilder.getPendingIntent(0, PendingIntent.FLAG_UPDATE_CURRENT);