Glide: load image to push notifications
This is expected. Since image is loaded from internet, it should always be in a async call or a background thread. You can use a async task or image loading libs like Glide.
To load image notification from a url, you can use the style "NotificationCompat.BigPictureStyle()". This requires a bitmap (which has to be extracted from image url)
Most of the API's and methods of Glide are now deprecated. Below is working with Glide 4.9 and upto Android 10.
// Load bitmap from image url on background thread and display image notification
private void getBitmapAsyncAndDoWork(String imageUrl) {
final Bitmap[] bitmap = {null};
Glide.with(getApplicationContext())
.asBitmap()
.load(imageUrl)
.into(new CustomTarget<Bitmap>() {
@Override
public void onResourceReady(@NonNull Bitmap resource, @Nullable Transition<? super Bitmap> transition) {
bitmap[0] = resource;
// TODO Do some work: pass this bitmap
displayImageNotification(bitmap[0]);
}
@Override
public void onLoadCleared(@Nullable Drawable placeholder) {
}
});
}
Display the image notification once, the bitmap is ready.
private void displayImageNotification(Bitmap bitmap) {
NotificationCompat.Builder builder = new NotificationCompat.Builder(getApplicationContext(), getChannelId());
builder
.setContentTitle(title)
.setContentText(subtext)
.setDefaults(Notification.DEFAULT_LIGHTS | Notification.DEFAULT_VIBRATE)
.setSmallIcon(SMALL_ICON)
.setPriority(NotificationCompat.PRIORITY_DEFAULT)
.setColor(getApplicationContext().getColor(color))
.setAutoCancel(true)
.setOngoing(false)
.setOnlyAlertOnce(true)
.setContentIntent(pendingIntent)
.setStyle(
new NotificationCompat.BigPictureStyle().bigPicture(bitmap))
.setPriority(Notification.PRIORITY_HIGH);
getManager().notify(tag, id, builder.build());
}
My solution:
public class NotificationBuilder {
public static void build(Context context) {
...
NotificationCompat.Builder notificationBuilder =
new NotificationCompat.Builder(context, channelId)
.setSmallIcon(R.drawable.app_icon_notification).setContentTitle("Title")
.setContentText("Description").setAutoCancel(true).setShowWhen(true)
.setWhen(1574521462).setLights(ledColor, 200, 2000)
.setPriority(NotificationCompat.PRIORITY_MAX)
.setStyle(new NotificationCompat.BigTextStyle().bigText("Description"))
.setTicker("Description").setSound(defaultSoundUri).setContentIntent(pendingIntent);
FutureTarget<Bitmap> futureTarget = GlideApp.with(context).asBitmap()
.load("http://example.com/myImage.jpg")
.circleCrop().submit();
LoadImageTask task = new LoadImageTask(icon -> {
notificationBuilder.setLargeIcon(icon);
GlideApp.with(context).clear(futureTarget);
notificationManager.notify(NotificationsCons.SUPPORT_MESSAGES_NOTIFICATION_ID,
notificationBuilder.build());
});
task.execute(futureTarget);
}
}
private static class LoadImageTask extends AsyncTask<FutureTarget<Bitmap>, Void, Bitmap> {
private OnSuccess onSuccess;
interface OnSuccess {
void onSuccess(Bitmap bitmap);
}
LoadImageTask(OnSuccess onSuccess) {
this.onSuccess = onSuccess;
}
@SafeVarargs @Override
protected final Bitmap doInBackground(FutureTarget<Bitmap>... futureTargets) {
try {
return futureTargets[0].get();
} catch (ExecutionException e) {
e.printStackTrace();
} catch (InterruptedException e) {
e.printStackTrace();
}
return null;
}
@Override protected void onPostExecute(Bitmap bitmap) {
super.onPostExecute(bitmap);
if (bitmap != null)
onSuccess.onSuccess(bitmap);
}
}
It works fine.
Try that way:
new Handler(Looper.getMainLooper()).post(new Runnable() {
@Override
public void run() {
Glide.with(context.getApplicationContext())
.load(item.getString("cover_img"))
.asBitmap()
.placeholder(placeholder)
.error(placeholder)
.into(notificationTarget);
}
});