Уведомление проходит старое задание

Я создаю уведомление внутри 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 я я могу получить foo_id из пакета Intent-Bundle (например, 1)

Однако, если запускается другое уведомление, и я нажимаю на него снова, активность по-прежнему получает "старое" значение (1) из пакета Intent-Bundle. Я попытался очистить связку с помощью clear(), но получаю тот же эффект. Я думаю, что с моим кодом не так.

Ответ 1

Вы отправляете один и тот же код запроса для ожидающего усиления. Измените это:

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

To:

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

intents не создаются, если вы отправляете одни и те же параметры. Они повторно используются.

Ответ 2

В качестве альтернативы вы можете использовать следующий код для создания своего PendingIntent:

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

Из документа для PendingIntent.FLAG_UPDATE_CURRENT:

Если описанный PendingIntent уже существует, сохраните его, но замените его дополнительные данные тем, что находится в этом новом намерении. Это можно использовать, если вы создаете намерения, в которых изменяются только дополнительные параметры, и им все равно, что любые объекты, которые получили ваш предыдущий PendingIntent, смогут запускать его с помощью ваших дополнительных дополнений, даже если они явно не предоставлены ему.

Ответ 3

Вы передаете тот же идентификатор. В такой ситуации создайте уникальный идентификатор из времени, подобного следующему:

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

И сформулируйте это так:

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

Ответ 4

Если вы ищете лучший подход после долгого времени, вам нужно передать PendingIntent.FLAG_UPDATE_CURRENT в качестве последнего аргумента, как показано ниже

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

вам даже не нужно предоставлять новый уникальный идентификатор.

Вы должны сделать это в следующий раз, а не в первый раз

Ответ 5

Ваш код запроса 0 для всех уведомлений. Измените следующую строку:

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

С:

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

Ответ 6

Просто хотел добавить еще один вариант

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