diff options
author | Santiago Etchebehere <santie@google.com> | 2019-06-28 19:40:48 -0700 |
---|---|---|
committer | android-build-merger <android-build-merger@google.com> | 2019-06-28 19:40:48 -0700 |
commit | 63deedad14459c35221cfc3737a9330656385352 (patch) | |
tree | 87e3e302f0fc3ffc2cb985597c5f1e5c43704bb9 | |
parent | 8056fb91459841071c9ad5a43deded6073c9c3ca (diff) | |
parent | 23b88fa0dac3021152513681ac06a806606d6983 (diff) | |
download | ThemePicker-63deedad14459c35221cfc3737a9330656385352.tar.gz |
Fix crash extracting wallpaper color
am: 23b88fa0da
Change-Id: I8466168bbab17105d0b097cad00a8c317a25438d
-rw-r--r-- | src/com/android/customization/picker/theme/ThemeFragment.java | 9 |
1 files changed, 9 insertions, 0 deletions
diff --git a/src/com/android/customization/picker/theme/ThemeFragment.java b/src/com/android/customization/picker/theme/ThemeFragment.java index cb78ea6d..f584dec9 100644 --- a/src/com/android/customization/picker/theme/ThemeFragment.java +++ b/src/com/android/customization/picker/theme/ThemeFragment.java @@ -22,6 +22,7 @@ import android.content.Intent; import android.content.res.ColorStateList; import android.content.res.Resources; import android.graphics.Bitmap; +import android.graphics.Bitmap.Config; import android.graphics.drawable.BitmapDrawable; import android.graphics.drawable.Drawable; import android.graphics.drawable.LayerDrawable; @@ -568,7 +569,15 @@ public class ThemeFragment extends ToolbarFragment { } view.findViewById(R.id.theme_preview_card_background).setBackground(background); if (mScrim == null && !mIsTranslucent) { + boolean shouldRecycle = false; + if (bitmap.getConfig() == Config.HARDWARE) { + bitmap = bitmap.copy(Config.ARGB_8888, false); + shouldRecycle = true; + } int colorsHint = WallpaperColors.fromBitmap(bitmap).getColorHints(); + if (shouldRecycle) { + bitmap.recycle(); + } TextView header = view.findViewById(R.id.theme_preview_card_header); if ((colorsHint & WallpaperColors.HINT_SUPPORTS_DARK_TEXT) == 0) { int colorLight = res.getColor(R.color.text_color_light, null); |