-
Notifications
You must be signed in to change notification settings - Fork 6.3k
Notifications
A notification is a message you can display to the user outside of your application's normal UI. Notifications appear in the phone's notification area and then can be expanded to see more information.
This is typically used to keep the user informed about events that are coming in that they should be aware of such as new email messages, new chat messages or an upcoming calendar event.
Notifications can include actions that let the user take a relevant action from within the notification drawer. At the minimum, all notifications consist of a base layout including:
- Icon of the app or relevant user image
- Title and message
- Timestamp
For a more detailed look at the design of notifications check out the Notifications Design guide.
Creating notifications is fairly straightforward. First you construct the notification using the NotificationCompat.Builder and then you add the notification to the NotificationManager.
Let's build a basic notification using the NotificationCompat.Builder. Typically this will contain at least an icon, a title, body:
NotificationCompat.Builder mBuilder =
new NotificationCompat.Builder(this)
.setSmallIcon(R.drawable.notification_icon)
.setContentTitle("My notification")
.setContentText("Hello World!");
Then we just have to append the notification using the NotificationManager:
NotificationManager mNotificationManager =
(NotificationManager) getSystemService(Context.NOTIFICATION_SERVICE);
// mId allows you to update the notification later on.
mNotificationManager.notify(mId, mBuilder.build());
A generic method for creating a simple notification might be:
// createNotification(56, R.drawable.ic_launcher, "New Message",
// "There is a new message from Bob!");
private void createNotification(int nId, int iconRes, String title, String body) {
NotificationCompat.Builder mBuilder = new NotificationCompat.Builder(
this).setSmallIcon(iconRes)
.setContentTitle(title)
.setContentText(body);
NotificationManager mNotificationManager =
(NotificationManager) getSystemService(Context.NOTIFICATION_SERVICE);
// mId allows you to update the notification later on.
mNotificationManager.notify(nId, mBuilder.build());
}
Notifications can also have actions attached that the user can perform by clicking. Although having an action attached to the notification is optional, you should almost always have at least one action attached.
The action inside the notification should be a PendingIntent which will fire when the user presses on the notification item.
// First let's define the intent to trigger when notification is selected
// Start out by creating a normal intent (in this case to open an activity)
Intent intent = new Intent(this, SomeActivity.class);
// Next, let's turn this into a PendingIntent using
// public static PendingIntent getActivity (Context context, int requestCode,
// Intent intent, int flags)
//Note : the flags is an important parameter
// if flag == 0, the extras set to intent for first time ever will be sent always irrespective of what you set //to intent everytime
// Set flag to PendingIntent.FLAG_UPDATE_CURRENT to pass updated extras set to Intent
PendingIntent pIntent = PendingIntent.getActivity(this, 0, intent, flags);
// Now we can attach this to the notification using setContentIntent
Notification noti =
new NotificationCompat.Builder(this)
.setSmallIcon(R.drawable.notification_icon)
.setContentTitle("My notification")
.setContentText("Hello World!")
.setContentIntent(pIntent).build();
// Hide the notification after its selected
noti.setAutoCancel(true);
NotificationManager mNotificationManager =
(NotificationManager) getSystemService(Context.NOTIFICATION_SERVICE);
// mId allows you to update the notification later on.
mNotificationManager.notify(0, noti);
You can also add up to three additional action buttons as well:
// Setup your pending intents first and
// then call addAction(int icon, CharSequence title, PendingIntent intent)
Notification noti = new NotificationCompat.Builder(this).
.....
.setContentIntent(pIntent)
.addAction(R.drawable.icon, "Share", sIntent)
.addAction(R.drawable.icon, "Ignore", iIntent).build();
Android 4.1 supports expandable notifications. You can also setup the notification to have an expanded view when pressed which gives additional details. See more about that on the official guide;
There are three styles to be used with the big view: big picture style, big text style, Inbox style. The following code demonstrates the usage of the BigTextStyle() which allows to use up to 256 dp.
Notification noti = new NotificationCompat.Builder(this).
.....
.setStyle(new NotificationCompat.BigTextStyle().bigText(longText))
The user can dismiss all notification or if you set your notification to auto-cancel it is also removed once the user selects it. You can also call the cancel() for a specific notification ID on the NotificationManager.
// Store some notification id as `nId`
NotificationManager mNotificationManager =
(NotificationManager) getSystemService(Context.NOTIFICATION_SERVICE);
mNotificationManager.cancel(nId);
See the official notifications guide for more details.
- http://developer.android.com/guide/topics/ui/notifiers/notifications.html
- http://developer.android.com/design/patterns/notifications.html
- http://www.vogella.com/articles/AndroidNotifications/article.html
- http://www.javacodegeeks.com/2013/08/android-notification-with-sound-and-icon-tutorial.html
- http://developer.android.com/reference/android/app/Notification.html
- http://developer.android.com/reference/android/support/v4/app/NotificationCompat.Builder.html
Created by CodePath with much help from the community. Contributed content licensed under cc-wiki with attribution required. You are free to remix and reuse, as long as you attribute and use a similar license.
Finding these guides helpful?
We need help from the broader community to improve these guides, add new topics and keep the topics up-to-date. See our contribution guidelines here and our topic issues list for great ways to help out.
Check these same guides through our standalone viewer for a better browsing experience and an improved search. Follow us on twitter @codepath for access to more useful Android development resources.