diff options
| author | Jernej Virag <jernej@google.com> | 2022-03-31 18:31:37 +0000 |
|---|---|---|
| committer | Android (Google) Code Review <android-gerrit@google.com> | 2022-03-31 18:31:37 +0000 |
| commit | 02725bd6698e372d7be641da3125095ea730768a (patch) | |
| tree | 42f0392ce8123e7c7a9baab2b854a19f59537dc9 /core/java | |
| parent | f5debd0bf50c5b9c62e1bf98397310c2244b77ef (diff) | |
| parent | 6a1ca2ff49bfb2a54326703d23e4a06d8db76743 (diff) | |
Merge "Fix loaded size of BigPicture bitmap" into tm-dev
Diffstat (limited to 'core/java')
| -rw-r--r-- | core/java/com/android/internal/widget/BigPictureNotificationImageView.java | 38 |
1 files changed, 22 insertions, 16 deletions
diff --git a/core/java/com/android/internal/widget/BigPictureNotificationImageView.java b/core/java/com/android/internal/widget/BigPictureNotificationImageView.java index c34a42224f5a..3a7cf74df4a8 100644 --- a/core/java/com/android/internal/widget/BigPictureNotificationImageView.java +++ b/core/java/com/android/internal/widget/BigPictureNotificationImageView.java @@ -20,16 +20,16 @@ import android.annotation.AttrRes; import android.annotation.NonNull; import android.annotation.Nullable; import android.annotation.StyleRes; +import android.app.ActivityManager; import android.content.Context; import android.graphics.drawable.Drawable; import android.graphics.drawable.Icon; import android.net.Uri; import android.util.AttributeSet; -import android.util.Log; import android.widget.ImageView; import android.widget.RemoteViews; -import java.io.IOException; +import com.android.internal.R; /** * An ImageView used by BigPicture Notifications to correctly resolve the Uri in an Icon using the @@ -41,22 +41,32 @@ public class BigPictureNotificationImageView extends ImageView { private static final String TAG = BigPictureNotificationImageView.class.getSimpleName(); + private final int mMaximumDrawableWidth; + private final int mMaximumDrawableHeight; + public BigPictureNotificationImageView(@NonNull Context context) { - super(context); + this(context, null, 0, 0); } public BigPictureNotificationImageView(@NonNull Context context, @Nullable AttributeSet attrs) { - super(context, attrs); + this(context, attrs, 0, 0); } public BigPictureNotificationImageView(@NonNull Context context, @Nullable AttributeSet attrs, @AttrRes int defStyleAttr) { - super(context, attrs, defStyleAttr); + this(context, attrs, defStyleAttr, 0); } public BigPictureNotificationImageView(@NonNull Context context, @Nullable AttributeSet attrs, @AttrRes int defStyleAttr, @StyleRes int defStyleRes) { super(context, attrs, defStyleAttr, defStyleRes); + boolean isLowRam = ActivityManager.isLowRamDeviceStatic(); + mMaximumDrawableWidth = context.getResources().getDimensionPixelSize( + isLowRam ? R.dimen.notification_big_picture_max_width_low_ram + : R.dimen.notification_big_picture_max_width); + mMaximumDrawableHeight = context.getResources().getDimensionPixelSize( + isLowRam ? R.dimen.notification_big_picture_max_height_low_ram + : R.dimen.notification_big_picture_max_height); } @Override @@ -85,21 +95,17 @@ public class BigPictureNotificationImageView extends ImageView { private Drawable loadImage(Uri uri) { if (uri == null) return null; - try { - return LocalImageResolver.resolveImage(uri, mContext); - } catch (IOException ex) { - Log.d(TAG, "Resolve failed from " + uri, ex); - return null; - } + return LocalImageResolver.resolveImage(uri, mContext, mMaximumDrawableWidth, + mMaximumDrawableHeight); } private Drawable loadImage(Icon icon) { if (icon == null) return null; - try { - return LocalImageResolver.resolveImage(icon, mContext); - } catch (IOException ex) { - Log.d(TAG, "Resolve failed from " + icon, ex); - return null; + Drawable drawable = LocalImageResolver.resolveImage(icon, mContext, mMaximumDrawableWidth, + mMaximumDrawableHeight); + if (drawable == null) { + return icon.loadDrawable(mContext); } + return drawable; } } |
