通知传递旧的Intent Extras

时间:2011-09-10 07:38:50

标签: android android-notifications android-pendingintent android-notification-bar

我正在通过以下代码在BroadcastReceiver中创建通知:

String ns = Context.NOTIFICATION_SERVICE;
        NotificationManager mNotificationManager = (NotificationManager) context.getSystemService(ns);
        int icon = R.drawable.ic_stat_notification;
        CharSequence tickerText = "New Notification";
        long when = System.currentTimeMillis();

        Notification notification = new Notification(icon, tickerText, when);
        notification.defaults |= Notification.DEFAULT_VIBRATE;
        long[] vibrate = {0,100,200,200,200,200};
        notification.vibrate = vibrate;
        notification.flags |= Notification.FLAG_AUTO_CANCEL;

        CharSequence contentTitle = "Title";
        CharSequence contentText = "Text";
        Intent notificationIntent = new Intent(context, NotificationActivity.class);
        notificationIntent.putExtra(Global.INTENT_EXTRA_FOO_ID, foo_id);
PendingIntent contentIntent = PendingIntent.getActivity(context, 0, notificationIntent, 0);

        notification.setLatestEventInfo(context, contentTitle, contentText, contentIntent);

        int mynotification_id = 1;

        mNotificationManager.notify(mynotification_id, notification);

当我点击通知时,它会打开NotificationActivity,在Activity中我可以从Intent-Bundle中检索foo_id(例如1)

但是,如果触发了另一个通知并再次单击它,则活动仍会从Intent-Bundle接收“旧”值(1)。我试图用clear()清除包,但收到的效果相同。我觉得我的代码错了......

6 个答案:

答案 0 :(得分:238)

您正在为待处理的强制发送相同的请求代码。 改变这个:

PendingIntent contentIntent = PendingIntent.getActivity(context, 0, notificationIntent, 0);

要:

PendingIntent contentIntent = PendingIntent.getActivity(context, UNIQUE_INT_PER_CALL, notificationIntent, 0);
如果您发送相同的参数,则不会创建

意图。它们被重复使用。

答案 1 :(得分:127)

或者,您可以使用以下代码生成PendingIntent:

PendingIntent contentIntent = PendingIntent.getActivity(context, 0, notificationIntent, PendingIntent.FLAG_UPDATE_CURRENT);

来自PendingIntent.FLAG_UPDATE_CURRENT的文档:

  

如果描述的PendingIntent已经存在,那么保留它,但用这个新Intent中的内容替换它的额外数据。如果您创建只有额外内容更改的意图,并且不关心接收到您之前的PendingIntent的任何实体将能够使用您的新附加功能启动它,即使它们未明确赋予它,也可以使用此功能。

答案 2 :(得分:38)

您传递的是相同的ID。在这种情况下,从这个时间做出一个独特的id:

int iUniqueId = (int) (System.currentTimeMillis() & 0xfffffff);

并将其作为:

PendingIntent contentIntent = PendingIntent.getActivity(getApplicationContext(),iUniqueId, intentForNotification, 0);

答案 3 :(得分:3)

对于长时间寻找最佳方法的人,您需要将 PendingIntent.FLAG_UPDATE_CURRENT 作为最后一个参数传递,如下所示

PendingIntent contentIntent = PendingIntent.getActivity(context, 0, notificationIntent, PendingIntent.FLAG_UPDATE_CURRENT);

您甚至不需要提供新的唯一ID。

答案 4 :(得分:0)

所有通知的请求代码均为0。更改以下行:

PendingIntent contentIntent = PendingIntent.getActivity(context, 0, notificationIntent, 0);

使用:

PendingIntent contentIntent = PendingIntent.getActivity(context, new Random().nextInt(), notificationIntent, 0);

答案 5 :(得分:0)

只想添加另一个选项

 PendingIntent.getBroadcast(context, 0, intent, PendingIntent.FLAG_ONE_SHOT | PendingIntent.FLAG_IMMUTABLE);