我在寻找类似问题的解决方案时遇到了这个问题。尽管这个问题是一年前的问题,但我会写下我是如何解决它的,以防它可以帮助其他人,因为我花了很多时间来解决我的问题。
我还将 android:launchMode 声明为“singleTask”的活动。通知是从服务发送的,并且该通知具有 PendingIntent 和打开 MyActivity 的 Intent。
我的解决方案是设置标志 FLAG_ACTIVITY_NEW_TASK (http://developer.android.com/reference/android/content/Intent.html#FLAG_ACTIVITY_NEW_TASK)在意图中。
然后创建 id 0 和 PendingIntent.FLAG_CANCEL_CURRENT 的 Pending Intent。
Intent _intent = new Intent(context, MyActivity.class);
_intent.setFlags(Intent.FLAG_ACTIVITY_NEW_TASK);
_intent.putExtra("DATA", myData);
PendingIntent _pIntent = PendingIntent.getActivity(context, 0, notificationIntent, PendingIntent.FLAG_CANCEL_CURRENT);
每当单击通知时,就会在新任务中创建 MyActivity 实例并调用 onCreate。意图包含正确的额外数据。
当我按下后退按钮并出现新通知时,意图始终会带来最新的额外数据。
如果该活动的实例已存在(例如当我按下主屏幕按钮时),新意图方法被调用并且意图带来正确的新的额外数据。
这在中清楚地解释了http://developer.android.com/guide/topics/manifest/activity-element.html#lmode。
我还尝试在 PendingIntent.getActivity 和 PendingIntent.FLAG_UPDATE_CURRENT 中对每个通知使用不同的请求代码(arg 2),但我认为秘密在于将 launchMode 定义为 singleTask 和 Intent.FLAG_ACTIVITY_NEW_TASK。
我还有另一种情况,其中 launchMode 是“标准”。这里的活动也是通过单击从服务发送的通知来启动的。
为了让启动的活动接收正确的额外数据,我设置了标志 FLAG_ACTIVITY_SINGLE_TOP。
_intent.setFlags(Intent.FLAG_ACTIVITY_SINGLE_TOP | Intent.FLAG_ACTIVITY_REORDER_TO_FRONT);
当活动的实例已经存在时(例如,当我按下主屏幕按钮时),此标志使得 onNewIntent 方法被调用。再次使用正确的额外数据。否则,也会使用正确的额外数据调用 onCreate (例如,当我按下后退按钮时)。
每次都会使用新的请求代码创建待处理意图,但它也应该适用于相同的请求代码。我认为秘密在于启动模式和意图标志设置。
PendingIntent pIntent = PendingIntent.getActivity(this, notificationRequestCode, _intent, PendingIntent.FLAG_CANCEL_CURRENT);