A demonstration of notification capability to contain photos
This demo consists of 2 approaches:
- BigPictureStyle: this is an Android built-in style of notification. It's easy and simple to implement, required only a few additional lines of code.
final NotificationCompat.BigPictureStyle style = new NotificationCompat.BigPictureStyle();
style.bigPicture(mPhotoItem);
builder.setStyle(style);
Because of the easy implementation, the feature with be limited to merely one picture for the whole notification.
- RemoteViews: this approach is a little more complicated than the previous method. Think of this as a custom view implementation, but with RemoteViews (the view used in app widget).
Notwithstanding the complicated implementation of appropriate RemoteViews (not covered in here), it is actually quite straightforward to insert the view.
RemoteViews bigContentView = getPhotosGridView(photosPerRow, totalPhotos);
builder.setContentTitle(getString(R.string.custom_notification_demo))
.setStyle(new NotificationCompat.DecoratedCustomViewStyle())
.setCustomBigContentView(bigContentView);
Similarly, the nofication collapsed view can be set with setCustomContentView.
Since it is RemoteViews, each view can be tied with an onClick event as long as it has its own distinguished ID. This can be done with setOnClickPendingIntent.
Keep in mind that in some circumstances, you will have to thoughtfully think about how you layout your view to perfectly suit the notification space.
- GridLayout: this approach still, in fact, uses the RemoteViews like the previous method, but it has significantly simplified the creating photo grid process (reducing convoluted calculations). The primary drawback is the fact that the layout is hardcoded, in other words you cannot change the number of photos per row programmatically.
In order for this approach to work, the GridLayout must be the original widget comes with official SDK, not the v7 library version.
- The maximum number of action buttons is 3 per notification.
- The maximum height of expanded notification is 256dp.
- The height of action buttons is the same as the actionBarSize.
- Keep in mind that the notification content is unscrollable, so exceeding the maximum height will result in some views being cut off.
- Last but not least, notification cannot contain collection elements, such as ListView, GridView, StackView and so on (due to this reason)