第二个操作的PendingIntent会覆盖第一个操作和contentIntent for Notification

Sar*_*ran 11 android android-notifications android-pendingintent

代码:

int id = 0;
NotificationCompat.Builder builder = new NotificationCompat.Builder(context)
  .setContentTitle(context.getString(R.string.notification_on_the_move_gps_title))
  .setContentText(context.getString(R.string.notification_on_the_move_text));

builder.setStyle(new NotificationCompat.BigTextStyle().bigText(context.getString(R.string.notification_on_the_move_gps_big_text)));

Intent mainIntent = new Intent(context, MainActivity.class);

Intent turnOffIntent = new Intent(context, MainActivity.class);
turnOffIntent.putExtra(MainApp.KEY_TURN_OFF_NOTIFICATION_ID, id);

TaskStackBuilder mainBuilder = TaskStackBuilder.create(context);
mainBuilder.addParentStack(MainActivity.class);
mainBuilder.addNextIntent(mainIntent);
PendingIntent mainPendingIntent = mainBuilder.getPendingIntent(0, PendingIntent.FLAG_UPDATE_CURRENT);
builder.setContentIntent(mainPendingIntent);

TaskStackBuilder turnOffBuilder = TaskStackBuilder.create(context);
turnOffBuilder.addParentStack(MainActivity.class);
turnOffBuilder.addNextIntent(turnOffIntent);
PendingIntent turnOffPendingIntent = turnOffBuilder.getPendingIntent(0, PendingIntent.FLAG_UPDATE_CURRENT);

builder
  .setSmallIcon(R.drawable.ic_stat_notification)
  .setLargeIcon(BitmapFactory.decodeResource(context.getResources(), R.drawable.ic_launcher))
  .setAutoCancel(true)
  .setLights(Color.BLUE, 500, 500)
  .setDefaults(Notification.DEFAULT_SOUND | Notification.DEFAULT_VIBRATE)
  .addAction(R.drawable.ic_stat_notification, "Open", mainPendingIntent)
  .addAction(R.drawable.ic_stat_notification_off, "Turn off", turnOffPendingIntent);

NotificationManager nm = (NotificationManager) context.getSystemService(Context.NOTIFICATION_SERVICE);
nm.notify(id, builder.build());
Run Code Online (Sandbox Code Playgroud)

问题:

单击未展开或扩展的通知正文或打开操作按钮始终使用(KEY_TURN_OFF_NOTIFICATION_ID)额外传递意图.

我试过放弃TaskStackBuilder并PendingIntent简单地创建:

Intent mainIntent = new Intent(context, MainActivity.class);
PendingIntent piMain = PendingIntent.getActivity(context, 0, mainIntent, 0);

Intent turnOffIntent = new Intent(context, MainActivity.class);
turnOffIntent.putExtra(MainApp.KEY_TURN_OFF_NOTIFICATION_ID, id);
PendingIntent piTurnOff = PendingIntent.getActivity(context, 0, turnOffIntent, 0);
Run Code Online (Sandbox Code Playgroud)

但是,为了同样的效果:(

如果我省略setContentIntent(),自然地,点击通知主体什么都不做.

如果我setContentIntent() 设置操作设置,则在MainActivity中永远不会收到额外信息.

fed*_*aol 16

来自doc:

由于这种行为,重要的是要知道两个Intent何时被认为是相同的,以便检索PendingIntent.人们常犯的一个错误是使用Intents创建多个PendingIntent对象,这些对象只在其"额外"内容中有所不同,期望每次都获得不同的PendingIntent.这不会发生.用于匹配的Intent部分与Intent.filterEquals定义的部分相同.如果你使用两个与Intent.filterEquals等效的Intent对象,那么你将获得两个相同的PendingIntent.

所以你必须使这些意图与方法不同Intent.filterEquals:

也就是说,如果他们的行为,数据,类型,类别和类别是相同的.这不会比较意图中包含的任何额外数据.

作为旁注,我在这里处理 firefox for android的下载通知时遇到了同样的问题

  • 在我看来,这是一个设计缺陷,肯定不是Android开发人员所犯的"错误". (7认同)
  • 我在`setType()`中塞了一些随机字符串,它运行正常,谢谢 (5认同)
  • 为每个人添加动作来区分他们是不同的.谢谢你的指点. (3认同)

dhe*_*ran 5

因此,PendingIntent.FLAG_UPDATE_CURRENT如果您要创建仅额外内容发生变化的新意图,则标记只会覆盖额外内容。

尝试添加不同的

  • intent.setAction("DISTINCT.ACTION.HERE")类似或的 动作
  • 类别如intent.addCategory("DISTINCT.CATEGORY.HERE")

对于每个意图。

干杯:-)