diff options
author | Mario Bertschler <bmario@google.com> | 2017-06-16 15:09:09 -0700 |
---|---|---|
committer | Mario Bertschler <bmario@google.com> | 2017-06-19 14:47:57 -0700 |
commit | 636e081ab720d43a233ff50177392dde6076e9d0 (patch) | |
tree | 67b1e566fddfad89c231ae22245f7cf1b343f6c8 /src/com/android/launcher3/compat | |
parent | b37200637d4ee83679be1cd23c3e5ae809fde78b (diff) | |
download | android_packages_apps_Trebuchet-636e081ab720d43a233ff50177392dde6076e9d0.tar.gz android_packages_apps_Trebuchet-636e081ab720d43a233ff50177392dde6076e9d0.tar.bz2 android_packages_apps_Trebuchet-636e081ab720d43a233ff50177392dde6076e9d0.zip |
Applying API changes on WallpaperColors.
Bug: 62719001
Change-Id: Iabe2e446bd05c41ec910ed2ad534d623285e7e63
Diffstat (limited to 'src/com/android/launcher3/compat')
3 files changed, 67 insertions, 42 deletions
diff --git a/src/com/android/launcher3/compat/WallpaperColorsCompat.java b/src/com/android/launcher3/compat/WallpaperColorsCompat.java index fd08f947e..58d2a8028 100644 --- a/src/com/android/launcher3/compat/WallpaperColorsCompat.java +++ b/src/com/android/launcher3/compat/WallpaperColorsCompat.java @@ -15,29 +15,40 @@ */ package com.android.launcher3.compat; -import android.util.SparseIntArray; - /** * A compatibility layer around platform implementation of WallpaperColors */ public class WallpaperColorsCompat { - private final SparseIntArray mColors; - private final boolean mSupportsDarkText; + public static final int HINT_SUPPORTS_DARK_TEXT = 0x1; + + private final int mPrimaryColor; + private final int mSecondaryColor; + private final int mTertiaryColor; + private final int mColorHints; + + public WallpaperColorsCompat(int primaryColor, int secondaryColor, int tertiaryColor, + int colorHints) { + mPrimaryColor = primaryColor; + mSecondaryColor = secondaryColor; + mTertiaryColor = tertiaryColor; + mColorHints = colorHints; + } - public WallpaperColorsCompat(SparseIntArray colors, boolean supportsDarkText) { - mColors = colors; - mSupportsDarkText = supportsDarkText; + public int getPrimaryColor() { + return mPrimaryColor; } - /** - * A map of color code to their occurrences. The bigger the int, the more relevant the color. - */ - public SparseIntArray getColors() { - return mColors; + public int getSecondaryColor() { + return mSecondaryColor; } - public boolean supportsDarkText() { - return mSupportsDarkText; + public int getTertiaryColor() { + return mTertiaryColor; } + + public int getColorHints() { + return mColorHints; + } + } diff --git a/src/com/android/launcher3/compat/WallpaperManagerCompatVL.java b/src/com/android/launcher3/compat/WallpaperManagerCompatVL.java index 8bdcedbbc..8e572ee1a 100644 --- a/src/com/android/launcher3/compat/WallpaperManagerCompatVL.java +++ b/src/com/android/launcher3/compat/WallpaperManagerCompatVL.java @@ -15,10 +15,6 @@ */ package com.android.launcher3.compat; -import static android.app.WallpaperManager.FLAG_SYSTEM; - -import static com.android.launcher3.Utilities.getDevicePrefs; - import android.app.WallpaperInfo; import android.app.WallpaperManager; import android.app.job.JobInfo; @@ -45,12 +41,17 @@ import android.support.annotation.Nullable; import android.support.v7.graphics.Palette; import android.util.Log; import android.util.Pair; -import android.util.SparseIntArray; import com.android.launcher3.Utilities; import java.io.IOException; import java.util.ArrayList; +import java.util.Collections; +import java.util.Comparator; +import java.util.List; + +import static android.app.WallpaperManager.FLAG_SYSTEM; +import static com.android.launcher3.Utilities.getDevicePrefs; public class WallpaperManagerCompatVL extends WallpaperManagerCompat { @@ -154,11 +155,12 @@ public class WallpaperManagerCompatVL extends WallpaperManagerCompat { return Pair.create(wallpaperId, null); } - SparseIntArray colorsToOccurrences = new SparseIntArray((parts.length - 2) / 2); - for (int i = 2; i < parts.length; i += 2) { - colorsToOccurrences.put(Integer.parseInt(parts[i]), Integer.parseInt(parts[i + 1])); - } - return Pair.create(wallpaperId, new WallpaperColorsCompat(colorsToOccurrences, false)); + int primary = parts.length > 2 ? Integer.parseInt(parts[2]) : 0; + int secondary = parts.length > 3 ? Integer.parseInt(parts[3]) : 0; + int tertiary = parts.length > 4 ? Integer.parseInt(parts[4]) : 0; + + return Pair.create(wallpaperId, new WallpaperColorsCompat(primary, secondary, tertiary, + 0 /* hints */)); } /** @@ -262,12 +264,22 @@ public class WallpaperManagerCompatVL extends WallpaperManagerCompat { bitmap.recycle(); StringBuilder builder = new StringBuilder(value); + List<Pair<Integer,Integer>> colorsToOccurrences = new ArrayList<>(); for (Palette.Swatch swatch : palette.getSwatches()) { - builder.append(',') - .append(swatch.getRgb()) - .append(',') - .append(swatch.getPopulation()); + colorsToOccurrences.add(new Pair(swatch.getRgb(), swatch.getPopulation())); } + + Collections.sort(colorsToOccurrences, new Comparator<Pair<Integer, Integer>>() { + @Override + public int compare(Pair<Integer, Integer> a, Pair<Integer, Integer> b) { + return b.second - a.second; + } + }); + + for (int i=0; i < Math.min(3, colorsToOccurrences.size()); i++) { + builder.append(',').append(colorsToOccurrences.get(i).first); + } + value = builder.toString(); } diff --git a/src/com/android/launcher3/compat/WallpaperManagerCompatVOMR1.java b/src/com/android/launcher3/compat/WallpaperManagerCompatVOMR1.java index c74ccc0cc..6233fabb2 100644 --- a/src/com/android/launcher3/compat/WallpaperManagerCompatVOMR1.java +++ b/src/com/android/launcher3/compat/WallpaperManagerCompatVOMR1.java @@ -22,13 +22,10 @@ import android.graphics.Color; import android.os.Build; import android.support.annotation.Nullable; import android.util.Log; -import android.util.Pair; -import android.util.SparseIntArray; import java.lang.reflect.InvocationHandler; import java.lang.reflect.Method; import java.lang.reflect.Proxy; -import java.util.List; @TargetApi(Build.VERSION_CODES.O) public class WallpaperManagerCompatVOMR1 extends WallpaperManagerCompat { @@ -41,8 +38,10 @@ public class WallpaperManagerCompatVOMR1 extends WallpaperManagerCompat { private final Method mAddOCLMethod; private final Method mWCGetMethod; - private final Method mWCGetColorsMethod; - private final Method mWCSupportsDarkTextMethod; + private final Method mWCGetPrimaryColorMethod; + private final Method mWCGetSecondaryColorMethod; + private final Method mWCGetTertiaryColorMethod; + private final Method mWCColorHintsMethod; WallpaperManagerCompatVOMR1(Context context) throws Exception { mWm = context.getSystemService(WallpaperManager.class); @@ -53,8 +52,10 @@ public class WallpaperManagerCompatVOMR1 extends WallpaperManagerCompat { mWCGetMethod = WallpaperManager.class.getDeclaredMethod("getWallpaperColors", int.class); Class wallpaperColorsClass = mWCGetMethod.getReturnType(); - mWCGetColorsMethod = wallpaperColorsClass.getDeclaredMethod("getColors"); - mWCSupportsDarkTextMethod = wallpaperColorsClass.getDeclaredMethod("supportsDarkText"); + mWCGetPrimaryColorMethod = wallpaperColorsClass.getDeclaredMethod("getPrimaryColor"); + mWCGetSecondaryColorMethod = wallpaperColorsClass.getDeclaredMethod("getSecondaryColor"); + mWCGetTertiaryColorMethod = wallpaperColorsClass.getDeclaredMethod("getTertiaryColor"); + mWCColorHintsMethod = wallpaperColorsClass.getDeclaredMethod("getColorHints"); } @Nullable @@ -98,12 +99,13 @@ public class WallpaperManagerCompatVOMR1 extends WallpaperManagerCompat { if (colors == null) { return null; } - List<Pair<Color, Integer>> list = (List) mWCGetColorsMethod.invoke(colors); - boolean supportsDarkText = (Boolean) mWCSupportsDarkTextMethod.invoke(colors); - SparseIntArray colorMap = new SparseIntArray(list.size()); - for (Pair<Color, Integer> color : list) { - colorMap.put(color.first.toArgb(), color.second); - } - return new WallpaperColorsCompat(colorMap, supportsDarkText); + Color primary = (Color) mWCGetPrimaryColorMethod.invoke(colors); + Color secondary = (Color) mWCGetSecondaryColorMethod.invoke(colors); + Color tertiary = (Color) mWCGetTertiaryColorMethod.invoke(colors); + int primaryVal = primary != null ? primary.toArgb() : 0; + int secondaryVal = secondary != null ? secondary.toArgb() : 0; + int tertiaryVal = tertiary != null ? tertiary.toArgb() : 0; + int colorHints = (Integer) mWCColorHintsMethod.invoke(colors); + return new WallpaperColorsCompat(primaryVal, secondaryVal, tertiaryVal, colorHints); } } |