Как именно использовать Notification.Builder - PullRequest
98 голосов
/ 18 июня 2011

Я обнаружил, что использую устаревший метод для уведомлений (messages.setLatestEventInfo ())

В нем говорится об использовании Notification.Builder.

  • Как мне его использовать?

Когда я пытаюсь создать новый экземпляр, он говорит мне:

Notification.Builder cannot be resolved to a type

Ответы [ 11 ]

151 голосов
/ 15 января 2012

Notification.Builder API 11 или NotificationCompat.Builder API 1

Это пример использования.

Intent notificationIntent = new Intent(ctx, YourClass.class);
PendingIntent contentIntent = PendingIntent.getActivity(ctx,
        YOUR_PI_REQ_CODE, notificationIntent,
        PendingIntent.FLAG_CANCEL_CURRENT);

NotificationManager nm = (NotificationManager) ctx
        .getSystemService(Context.NOTIFICATION_SERVICE);

Resources res = ctx.getResources();
Notification.Builder builder = new Notification.Builder(ctx);

builder.setContentIntent(contentIntent)
            .setSmallIcon(R.drawable.some_img)
            .setLargeIcon(BitmapFactory.decodeResource(res, R.drawable.some_big_img))
            .setTicker(res.getString(R.string.your_ticker))
            .setWhen(System.currentTimeMillis())
            .setAutoCancel(true)
            .setContentTitle(res.getString(R.string.your_notif_title))
            .setContentText(res.getString(R.string.your_notif_text));
Notification n = builder.build();

nm.notify(YOUR_NOTIF_ID, n);
86 голосов
/ 18 июня 2011

Это в API 11, поэтому если вы разрабатываете для чего-то более раннего, чем 3.0, вы должны продолжать использовать старый API.

Обновление : NotificationCompatКласс .Builder был добавлен в пакет поддержки, поэтому мы можем использовать его для поддержки API уровня v4 и выше:

http://developer.android.com/reference/android/support/v4/app/NotificationCompat.Builder.html

70 голосов
/ 04 января 2013

в дополнение к выбранному ответу приведен пример кода для NotificationCompat.Builder класса из Source Tricks :

// Add app running notification  

    private void addNotification() {



    NotificationCompat.Builder builder =  
            new NotificationCompat.Builder(this)  
            .setSmallIcon(R.drawable.ic_launcher)  
            .setContentTitle("Notifications Example")  
            .setContentText("This is a test notification");  

    Intent notificationIntent = new Intent(this, MainActivity.class);  
    PendingIntent contentIntent = PendingIntent.getActivity(this, 0, notificationIntent,   
            PendingIntent.FLAG_UPDATE_CURRENT);  
    builder.setContentIntent(contentIntent);  

    // Add as notification  
    NotificationManager manager = (NotificationManager) getSystemService(Context.NOTIFICATION_SERVICE);  
    manager.notify(FM_NOTIFICATION_ID, builder.build());  
}  

// Remove notification  
private void removeNotification() {  
    NotificationManager manager = (NotificationManager) getSystemService(Context.NOTIFICATION_SERVICE);  
    manager.cancel(FM_NOTIFICATION_ID);  
}  
4 голосов
/ 18 июня 2011

Notification Builder предназначен исключительно для Android API уровня 11 и выше (Android 3.0 и выше).

Следовательно, если вы не нацелены на планшеты Honeycomb, вам не следует использовать Notification Builder, а следует придерживаться более старых методов создания уведомлений, таких как следующий пример .

2 голосов
/ 10 марта 2016

ОБНОВЛЕНИЕ android-N (март-2016)

Пожалуйста, посетите Уведомления Обновления ссылку для более подробной информации.

  • Прямой ответ
  • Связанные уведомления
  • Пользовательские виды

Android N также позволяет объединять похожие уведомления для отображения в виде одно уведомление. Чтобы сделать это возможным, Android N использует существующий NotificationCompat.Builder.setGroup() метод. Пользователи могут разверните каждое из уведомлений и выполните такие действия, как ответ и отклонить каждое уведомление отдельно от тень уведомления.

Это уже существующий пример, демонстрирующий простую службу, которая отправляет уведомления с использованием NotificationCompat. Каждый непрочитанный разговор с пользователь отправляется как отдельное уведомление.

Этот образец был обновлен, чтобы воспользоваться новым уведомлением функции, доступные в Android N.

пример кода .

2 голосов
/ 01 сентября 2014

У меня возникла проблема при создании уведомлений (только для Android 4.0+). Эта ссылка показала мне точно, что я делаю неправильно, и говорит следующее:

Required notification contents

A Notification object must contain the following:

A small icon, set by setSmallIcon()
A title, set by setContentTitle()
Detail text, set by setContentText()

В основном я скучал по одному из них. Просто в качестве основы для устранения неполадок с этим, убедитесь, что у вас есть все это по крайней мере. Надеюсь, это спасет кого-то еще от головной боли.

1 голос
/ 24 сентября 2016

Я использовал

Intent intent = new Intent(this, MainActivity.class);
        intent.addFlags(Intent.FLAG_ACTIVITY_CLEAR_TOP);
        PendingIntent pendingIntent = PendingIntent.getActivity(this, 0, intent,
                PendingIntent.FLAG_ONE_SHOT);

        Uri defaultSoundUri= RingtoneManager.getDefaultUri(RingtoneManager.TYPE_NOTIFICATION);
        NotificationCompat.Builder notificationBuilder = new NotificationCompat.Builder(this)
                .setSmallIcon(R.mipmap.ic_launcher)
                .setContentTitle("Firebase Push Notification")
                .setContentText(messageBody)
                .setAutoCancel(true)
                .setSound(defaultSoundUri)
                .setContentIntent(pendingIntent);

        NotificationManager notificationManager =
                (NotificationManager) getSystemService(Context.NOTIFICATION_SERVICE);

        notificationManager.notify(0, notificationBuilder.build());
1 голос
/ 22 июня 2015

Это работает даже в API 8, вы можете использовать этот код:

 Notification n = 
   new Notification(R.drawable.yourownpicturehere, getString(R.string.noticeMe), 
System.currentTimeMillis());

PendingIntent i=PendingIntent.getActivity(this, 0,
             new Intent(this, NotifyActivity.class),
                               0);
n.setLatestEventInfo(getApplicationContext(), getString(R.string.title), getString(R.string.message), i);
n.number=++count;
n.flags |= Notification.FLAG_AUTO_CANCEL;
n.flags |= Notification.DEFAULT_SOUND;
n.flags |= Notification.DEFAULT_VIBRATE;
n.ledARGB = 0xff0000ff;
n.flags |= Notification.FLAG_SHOW_LIGHTS;

// Now invoke the Notification Service
String notifService = Context.NOTIFICATION_SERVICE;
NotificationManager mgr = 
   (NotificationManager) getSystemService(notifService);
mgr.notify(NOTIFICATION_ID, n);

Или я предлагаю следовать превосходному учебнику об этом

1 голос
/ 27 апреля 2013

В случае, если это кому-нибудь поможет ... У меня возникли большие проблемы с настройкой уведомлений с помощью пакета поддержки при тестировании на более новых и старых API. Я смог заставить их работать на более новом устройстве, но получал тестирование ошибок на старом устройстве. В итоге у меня получилось удалить все импорта, связанные с функциями уведомлений. В частности, NotificationCompat и TaskStackBuilder. Похоже, что при настройке моего кода в начале импорт был добавлен из новой сборки, а не из пакета поддержки. Затем, когда я захотел реализовать эти элементы позже в Eclipse, мне не предложили импортировать их снова. Надеюсь, что это имеет смысл, и что это помогает кому-то еще:)

0 голосов

Автономный пример

Та же методика, что и в этот ответ , но:

  • автономный: скопируйте и вставьте егоскомпилирует и запустит
  • с кнопкой, чтобы вы сгенерировали столько уведомлений, сколько вам нужно, и поиграйте с намерениями и идентификаторами уведомлений

Источник:

import android.app.Activity;
import android.app.Notification;
import android.app.NotificationManager;
import android.app.PendingIntent;
import android.content.Context;
import android.content.Intent;
import android.graphics.Color;
import android.os.Bundle;
import android.view.View;
import android.widget.Button;

public class Main extends Activity {
    private int i;
    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        final Button button = new Button(this);
        button.setText("click me");
        button.setOnClickListener(new View.OnClickListener() {
            @Override
            public void onClick(View view) {
                final Notification notification = new Notification.Builder(Main.this)
                        /* Make app open when you click on the notification. */
                        .setContentIntent(PendingIntent.getActivity(
                                Main.this,
                                Main.this.i,
                                new Intent(Main.this, Main.class),
                                PendingIntent.FLAG_CANCEL_CURRENT))
                        .setContentTitle("title")
                        .setAutoCancel(true)
                        .setContentText(String.format("id = %d", Main.this.i))
                        // Starting on Android 5, only the alpha channel of the image matters.
                        // https://stackoverflow.com/a/35278871/895245
                        // `android.R.drawable` resources all seem suitable.
                        .setSmallIcon(android.R.drawable.star_on)
                        // Color of the background on which the alpha image wil drawn white.
                        .setColor(Color.RED)
                        .build();
                final NotificationManager notificationManager =
                        (NotificationManager)getSystemService(Context.NOTIFICATION_SERVICE);
                notificationManager.notify(Main.this.i, notification);
                // If the same ID were used twice, the second notification would replace the first one. 
                //notificationManager.notify(0, notification);
                Main.this.i++;
            }
        });
        this.setContentView(button);
    }
}

Протестировано в Android 22.

...