Android - Benachrichtigungen
EIN notificationist eine Nachricht, die Sie dem Benutzer außerhalb der normalen Benutzeroberfläche Ihrer Anwendung anzeigen können. Wenn Sie das System anweisen, eine Benachrichtigung auszugeben, wird diese zuerst als Symbol im Benachrichtigungsbereich angezeigt. Um die Details der Benachrichtigung anzuzeigen, öffnet der Benutzer die Benachrichtigungsleiste. Sowohl der Benachrichtigungsbereich als auch die Benachrichtigungsleiste sind systemgesteuerte Bereiche, die der Benutzer jederzeit anzeigen kann.
Android Toast class bietet eine praktische Möglichkeit, Benutzerwarnungen anzuzeigen. Das Problem besteht jedoch darin, dass diese Warnungen nicht dauerhaft sind. Dies bedeutet, dass die Warnung einige Sekunden lang auf dem Bildschirm blinkt und dann verschwindet.
Um die Details der Benachrichtigung anzuzeigen, müssen Sie das Symbol auswählen, das die Benachrichtigungsleiste mit Details zur Benachrichtigung anzeigt. Während Sie mit einem Emulator mit einem virtuellen Gerät arbeiten, müssen Sie auf die Statusleiste klicken und sie nach unten ziehen, um sie zu erweitern. Dadurch erhalten Sie folgende Details. Das wird gerecht64 dp groß und normale Sicht genannt.
Oben erweiterte Form kann eine haben Big ViewHier finden Sie weitere Details zur Benachrichtigung. Sie können der Benachrichtigung bis zu sechs zusätzliche Zeilen hinzufügen. Der folgende Screenshot zeigt eine solche Benachrichtigung.
Benachrichtigungen erstellen und senden
Sie haben eine einfache Möglichkeit, eine Benachrichtigung zu erstellen. Führen Sie die folgenden Schritte in Ihrer Anwendung aus, um eine Benachrichtigung zu erstellen:
Schritt 1 - Benachrichtigungs-Generator erstellen
In einem ersten Schritt erstellen Sie einen Benachrichtigungs-Builder mit NotificationCompat.Builder.build () . Mit dem Notification Builder können Sie verschiedene Benachrichtigungseigenschaften wie kleine und große Symbole, Titel, Priorität usw. festlegen.
NotificationCompat.Builder mBuilder = new NotificationCompat.Builder(this)
Schritt 2 - Festlegen der Benachrichtigungseigenschaften
Sobald du hast BuilderObjekt können Sie die Benachrichtigungseigenschaften mithilfe des Builder-Objekts gemäß Ihren Anforderungen festlegen. Dies ist jedoch obligatorisch, um mindestens Folgendes festzulegen:
Ein kleines Symbol, gesetzt von setSmallIcon()
Ein Titel, festgelegt von setContentTitle()
Detailtext, festgelegt von setContentText()
mBuilder.setSmallIcon(R.drawable.notification_icon);
mBuilder.setContentTitle("Notification Alert, Click Me!");
mBuilder.setContentText("Hi, This is Android Notification Detail!");
Sie haben viele optionale Eigenschaften, die Sie für Ihre Benachrichtigung festlegen können. Weitere Informationen finden Sie in der Referenzdokumentation zu NotificationCompat.Builder.
Schritt 3 - Aktionen anhängen
Dies ist ein optionaler Teil und erforderlich, wenn Sie der Benachrichtigung eine Aktion hinzufügen möchten. Mit einer Aktion können Benutzer direkt von der Benachrichtigung zu einer wechselnActivity in Ihrer Anwendung, wo sie ein oder mehrere Ereignisse anzeigen oder weitere Arbeiten ausführen können.
Die Aktion wird durch a definiert PendingIntent mit einem IntentDamit wird eine Aktivität in Ihrer Anwendung gestartet. Rufen Sie die entsprechende Methode von NotificationCompat.Builder auf , um PendingIntent einer Geste zuzuordnen . Wenn Sie beispielsweise die Aktivität starten möchten, wenn der Benutzer auf den Benachrichtigungstext in der Benachrichtigungsleiste klickt, fügen Sie den PendingIntent durch Aufrufen hinzusetContentIntent().
Mit einem PendingIntent-Objekt können Sie häufig zu einem späteren Zeitpunkt eine Aktion in Ihrem Anwendungsnamen ausführen, ohne sich darum zu kümmern, ob Ihre Anwendung ausgeführt wird oder nicht.
Wir verwenden ein Stack Builder-Objekt, das einen künstlichen Backstack für die gestartete Aktivität enthält. Dadurch wird sichergestellt, dass das Rückwärtsnavigieren von der Aktivität aus Ihrer Anwendung zum Startbildschirm führt.
Intent resultIntent = new Intent(this, ResultActivity.class);
TaskStackBuilder stackBuilder = TaskStackBuilder.create(this);
stackBuilder.addParentStack(ResultActivity.class);
// Adds the Intent that starts the Activity to the top of the stack
stackBuilder.addNextIntent(resultIntent);
PendingIntent resultPendingIntent = stackBuilder.getPendingIntent(0,PendingIntent.FLAG_UPDATE_CURRENT);
mBuilder.setContentIntent(resultPendingIntent);
Schritt 4 - Geben Sie die Benachrichtigung aus
Schließlich übergeben Sie das Notification-Objekt an das System, indem Sie NotificationManager.notify () aufrufen, um Ihre Benachrichtigung zu senden. Stellen Sie sicher, dass Sie anrufenNotificationCompat.Builder.build()Methode für das Builder-Objekt, bevor es benachrichtigt wird. Diese Methode kombiniert alle festgelegten Optionen und gibt eine neue zurückNotification Objekt.
NotificationManager mNotificationManager = (NotificationManager) getSystemService(Context.NOTIFICATION_SERVICE);
// notificationID allows you to update the notification later on.
mNotificationManager.notify(notificationID, mBuilder.build());
Die NotificationCompat.Builder-Klasse
Die NotificationCompat.Builder-Klasse ermöglicht eine einfachere Steuerung aller Flags sowie die Erstellung der typischen Benachrichtigungslayouts. Im Folgenden sind einige wichtige und am häufigsten verwendete Methoden aufgeführt, die als Teil der NotificationCompat.Builder-Klasse verfügbar sind.
Sr.Nr. | Konstanten & Beschreibung |
---|---|
1 | Notification build() Kombinieren Sie alle festgelegten Optionen und geben Sie ein neues Benachrichtigungsobjekt zurück. |
2 | NotificationCompat.Builder setAutoCancel (boolean autoCancel) Durch Setzen dieses Flags wird die Benachrichtigung automatisch abgebrochen, wenn der Benutzer im Bedienfeld darauf klickt. |
3 | NotificationCompat.Builder setContent (RemoteViews views) Stellen Sie benutzerdefinierte RemoteViews bereit, die anstelle der Standard-RemoteViews verwendet werden sollen. |
4 | NotificationCompat.Builder setContentInfo (CharSequence info) Stellen Sie den großen Text auf der rechten Seite der Benachrichtigung ein. |
5 | NotificationCompat.Builder setContentIntent (PendingIntent intent) Geben Sie einen PendingIntent an, der gesendet werden soll, wenn auf die Benachrichtigung geklickt wird. |
6 | NotificationCompat.Builder setContentText (CharSequence text) Legen Sie den Text (zweite Zeile) der Benachrichtigung in einer Standardbenachrichtigung fest. |
7 | NotificationCompat.Builder setContentTitle (CharSequence title) Legen Sie den Text (erste Zeile) der Benachrichtigung in einer Standardbenachrichtigung fest. |
8 | NotificationCompat.Builder setDefaults (int defaults) Legen Sie die Standardbenachrichtigungsoptionen fest, die verwendet werden sollen. |
9 | NotificationCompat.Builder setLargeIcon (Bitmap icon) Stellen Sie das große Symbol ein, das im Ticker und in der Benachrichtigung angezeigt wird. |
10 | NotificationCompat.Builder setNumber (int number) Stellen Sie die große Zahl auf der rechten Seite der Benachrichtigung ein. |
11 | NotificationCompat.Builder setOngoing (boolean ongoing) Legen Sie fest, ob dies eine laufende Benachrichtigung ist. |
12 | NotificationCompat.Builder setSmallIcon (int icon) Stellen Sie das kleine Symbol für die Benachrichtigungslayouts ein. |
13 | NotificationCompat.Builder setStyle (NotificationCompat.Style style) Fügen Sie einen umfangreichen Benachrichtigungsstil hinzu, der beim Erstellen angewendet werden soll. |
14 | NotificationCompat.Builder setTicker (CharSequence tickerText) Legen Sie den Text fest, der in der Statusleiste angezeigt wird, wenn die Benachrichtigung zum ersten Mal eintrifft. |
15 | NotificationCompat.Builder setVibrate (long[] pattern) Stellen Sie das zu verwendende Vibrationsmuster ein. |
16 | NotificationCompat.Builder setWhen (long when) Stellen Sie die Zeit ein, zu der das Ereignis aufgetreten ist. Benachrichtigungen im Bereich werden nach diesem Zeitpunkt sortiert. |
Beispiel
Das folgende Beispiel zeigt die Funktionalität einer Android-Benachrichtigung mit a NotificationCompat.Builder Klasse, die in Android 4.1 eingeführt wurde.
Schritt | Beschreibung |
---|---|
1 | Sie werden Android Studio IDE verwenden, um eine Android-Anwendung zu erstellen und sie als Tutorialpunkt unter einem Paket com.example.notificationdemo zu benennen . |
2 | Ändern src / MainActivity.java Datei und fügen Sie den Code in Kenntnis zu setzen ( „“), wenn der Benutzer klicken Sie auf den Button, wird es Android - Benachrichtigungsdienst rufen. |
3 | Erstellen Sie eine neue Java-Datei src / NotificationView.java , die verwendet wird, um ein neues Layout als Teil einer neuen Aktivität anzuzeigen, die gestartet wird, wenn der Benutzer auf eine der Benachrichtigungen klickt |
4 | Ändern Sie die Layout-XML-Datei res / layout / activity_main.xml , um die Schaltfläche Benachrichtigung im relativen Layout hinzuzufügen. |
5 | Erstellen Sie eine neue Layout-XML-Datei res / layout / notification.xml . Dies wird als Layoutdatei für neue Aktivitäten verwendet, die gestartet werden, wenn der Benutzer auf eine der Benachrichtigungen klickt. |
6 | Die Standardzeichenfolgenkonstanten müssen nicht geändert werden. Android Studio kümmert sich um Standard-String-Konstanten |
7 | Führen Sie die Anwendung aus, um den Android-Emulator zu starten, und überprüfen Sie das Ergebnis der in der Anwendung vorgenommenen Änderungen. |
Es folgt der Inhalt der geänderten Hauptaktivitätsdatei src/com.example.notificationdemo/MainActivity.java. Diese Datei kann jede der grundlegenden Lebenszyklusmethoden enthalten.
package com.example.notificationdemo;
import android.app.Activity;
import android.app.NotificationManager;
import android.app.PendingIntent;
import android.content.Context;
import android.content.Intent;
import android.support.v4.app.NotificationCompat;
import android.os.Bundle;
import android.view.View;
import android.widget.Button;
public class MainActivity extends Activity {
Button b1;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
b1 = (Button)findViewById(R.id.button);
b1.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View v) {
addNotification();
}
});
}
private void addNotification() {
NotificationCompat.Builder builder =
new NotificationCompat.Builder(this)
.setSmallIcon(R.drawable.abc)
.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(0, builder.build());
}
}
Es folgt der Inhalt von res/layout/notification.xml Datei -
<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:orientation="vertical"
android:layout_width="fill_parent"
android:layout_height="fill_parent" >
<TextView
android:layout_width="fill_parent"
android:layout_height="400dp"
android:text="Hi, Your Detailed notification view goes here...." />
</LinearLayout>
Es folgt der Inhalt der geänderten Hauptaktivitätsdatei src/com.example.notificationdemo/NotificationView.java.
package com.example.notificationdemo;
import android.os.Bundle;
import android.app.Activity;
public class NotificationView extends Activity{
@Override
public void onCreate(Bundle savedInstanceState){
super.onCreate(savedInstanceState);
setContentView(R.layout.notification);
}
}
Es folgt der Inhalt von res/layout/activity_main.xml Datei -
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:tools="http://schemas.android.com/tools"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:paddingBottom="@dimen/activity_vertical_margin"
android:paddingLeft="@dimen/activity_horizontal_margin"
android:paddingRight="@dimen/activity_horizontal_margin"
android:paddingTop="@dimen/activity_vertical_margin"
tools:context="MainActivity">
<TextView
android:id="@+id/textView1"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:text="Notification Example"
android:layout_alignParentTop="true"
android:layout_centerHorizontal="true"
android:textSize="30dp" />
<TextView
android:id="@+id/textView2"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:text="Tutorials point "
android:textColor="#ff87ff09"
android:textSize="30dp"
android:layout_below="@+id/textView1"
android:layout_centerHorizontal="true"
android:layout_marginTop="48dp" />
<ImageButton
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:id="@+id/imageButton"
android:src="@drawable/abc"
android:layout_below="@+id/textView2"
android:layout_centerHorizontal="true"
android:layout_marginTop="42dp" />
<Button
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:text="Notification"
android:id="@+id/button"
android:layout_marginTop="62dp"
android:layout_below="@+id/imageButton"
android:layout_centerHorizontal="true" />
</RelativeLayout>
Es folgt der Inhalt von res/values/strings.xml zwei neue Konstanten definieren -
<?xml version="1.0" encoding="utf-8"?>
<resources>
<string name="action_settings">Settings</string>
<string name="app_name">tutorialspoint </string>
</resources>
Es folgt der Standardinhalt von AndroidManifest.xml - -
<?xml version="1.0" encoding="utf-8"?>
<manifest xmlns:android="http://schemas.android.com/apk/res/android"
package="com.example.notificationdemo" >
<application
android:allowBackup="true"
android:icon="@drawable/ic_launcher"
android:label="@string/app_name"
android:theme="@style/AppTheme" >
<activity
android:name="com.example.notificationdemo.MainActivity"
android:label="@string/app_name" >
<intent-filter>
<action android:name="android.intent.action.MAIN" />
<category android:name="android.intent.category.LAUNCHER" />
</intent-filter>
</activity>
<activity android:name=".NotificationView"
android:label="Details of notification"
android:parentActivityName=".MainActivity">
<meta-data
android:name="android.support.PARENT_ACTIVITY"
android:value=".MainActivity"/>
</activity>
</application>
</manifest>
Lassen Sie uns versuchen, Ihre auszuführen tutorialspointAnwendung. Ich nehme an, Sie hatten Ihre erstelltAVDwährend der Einrichtung der Umgebung. Um die APP in Android Studio auszuführen, öffnen Sie eine der Aktivitätsdateien Ihres Projekts und klicken Sie in
Klicken Sie nun auf buttonOben sehen Sie eine Meldung "New Message Alert!" wird kurz angezeigt und danach wird der folgende Bildschirm mit einem kleinen Symbol in der oberen linken Ecke angezeigt.
Erweitern Sie nun die Ansicht, klicken Sie lange auf das kleine Symbol. Nach einer Sekunde werden Datumsinformationen angezeigt. In dieser Zeit sollten Sie die Statusleiste nach unten ziehen, ohne die Maus loszulassen. Sie werden sehen, dass die Statusleiste erweitert wird und Sie den folgenden Bildschirm erhalten -
Big View-Benachrichtigung
Das folgende Code-Snippet zeigt, wie Sie die im vorherigen Snippet erstellte Benachrichtigung ändern, um den Big View-Stil "Posteingang" zu verwenden. Ich werde die Änderungsmethode displayNotification () aktualisieren, um diese Funktionalität zu zeigen -
protected void displayNotification() {
Log.i("Start", "notification");
/* Invoking the default notification service */
NotificationCompat.Builder mBuilder = new NotificationCompat.Builder(this);
mBuilder.setContentTitle("New Message");
mBuilder.setContentText("You've received new message.");
mBuilder.setTicker("New Message Alert!");
mBuilder.setSmallIcon(R.drawable.woman);
/* Increase notification number every time a new notification arrives */
mBuilder.setNumber(++numMessages);
/* Add Big View Specific Configuration */
NotificationCompat.InboxStyle inboxStyle = new NotificationCompat.InboxStyle();
String[] events = new String[6];
events[0] = new String("This is first line....");
events[1] = new String("This is second line...");
events[2] = new String("This is third line...");
events[3] = new String("This is 4th line...");
events[4] = new String("This is 5th line...");
events[5] = new String("This is 6th line...");
// Sets a title for the Inbox style big view
inboxStyle.setBigContentTitle("Big Title Details:");
// Moves events into the big view
for (int i=0; i < events.length; i++) {
inboxStyle.addLine(events[i]);
}
mBuilder.setStyle(inboxStyle);
/* Creates an explicit intent for an Activity in your app */
Intent resultIntent = new Intent(this, NotificationView.class);
TaskStackBuilder stackBuilder = TaskStackBuilder.create(this);
stackBuilder.addParentStack(NotificationView.class);
/* Adds the Intent that starts the Activity to the top of the stack */
stackBuilder.addNextIntent(resultIntent);
PendingIntent resultPendingIntent =stackBuilder.getPendingIntent(0,PendingIntent.FLAG_UPDATE_CURRENT);
mBuilder.setContentIntent(resultPendingIntent);
mNotificationManager = (NotificationManager) getSystemService(Context.NOTIFICATION_SERVICE);
/* notificationID allows you to update the notification later on. */
mNotificationManager.notify(notificationID, mBuilder.build());
}
Wenn Sie nun versuchen, Ihre Anwendung auszuführen, finden Sie das folgende Ergebnis in erweiterter Form der Ansicht: