X-Git-Url: https://git.ktnx.net/?a=blobdiff_plain;f=app%2Fsrc%2Fmain%2Fjava%2Fnet%2Fktnx%2Fmobileledger%2Futils%2FColors.java;h=277de9ff0c99c172c13c7262c78479fdfafaae4e;hb=2718441df5eb725029fd223cc46a9a28e56a6a0a;hp=9342e052d4510e70a151b5203e63944e7a8dc90e;hpb=0fc2ddc465cd9b9314ae336e69535020a96a7fbc;p=mobile-ledger-staging.git diff --git a/app/src/main/java/net/ktnx/mobileledger/utils/Colors.java b/app/src/main/java/net/ktnx/mobileledger/utils/Colors.java index 9342e052..277de9ff 100644 --- a/app/src/main/java/net/ktnx/mobileledger/utils/Colors.java +++ b/app/src/main/java/net/ktnx/mobileledger/utils/Colors.java @@ -18,19 +18,22 @@ package net.ktnx.mobileledger.utils; import android.app.Activity; +import android.content.res.ColorStateList; import android.content.res.Resources; import android.util.TypedValue; +import androidx.annotation.ColorInt; +import androidx.annotation.ColorLong; +import androidx.annotation.NonNull; +import androidx.lifecycle.MutableLiveData; + import net.ktnx.mobileledger.R; import net.ktnx.mobileledger.model.Data; import net.ktnx.mobileledger.model.MobileLedgerProfile; +import net.ktnx.mobileledger.ui.HueRing; import java.util.Locale; -import androidx.annotation.ColorInt; -import androidx.annotation.ColorLong; -import androidx.lifecycle.MutableLiveData; - import static java.lang.Math.abs; import static net.ktnx.mobileledger.utils.Logger.debug; @@ -38,6 +41,7 @@ public class Colors { public static final int DEFAULT_HUE_DEG = 261; private static final float blueLightness = 0.665f; private static final float yellowLightness = 0.350f; + private static final int[][] EMPTY_STATES = new int[][]{new int[0]}; public static @ColorInt int accent; @ColorInt @@ -48,6 +52,44 @@ public class Colors { public static int primary, defaultTextColor; public static int profileThemeId = -1; public static MutableLiveData themeWatch = new MutableLiveData<>(0); + private static int[] themeIDs = + {R.style.AppTheme_NoActionBar_000, R.style.AppTheme_NoActionBar_005, + R.style.AppTheme_NoActionBar_010, R.style.AppTheme_NoActionBar_015, + R.style.AppTheme_NoActionBar_020, R.style.AppTheme_NoActionBar_025, + R.style.AppTheme_NoActionBar_030, R.style.AppTheme_NoActionBar_035, + R.style.AppTheme_NoActionBar_040, R.style.AppTheme_NoActionBar_045, + R.style.AppTheme_NoActionBar_050, R.style.AppTheme_NoActionBar_055, + R.style.AppTheme_NoActionBar_060, R.style.AppTheme_NoActionBar_065, + R.style.AppTheme_NoActionBar_070, R.style.AppTheme_NoActionBar_075, + R.style.AppTheme_NoActionBar_080, R.style.AppTheme_NoActionBar_085, + R.style.AppTheme_NoActionBar_090, R.style.AppTheme_NoActionBar_095, + R.style.AppTheme_NoActionBar_100, R.style.AppTheme_NoActionBar_105, + R.style.AppTheme_NoActionBar_110, R.style.AppTheme_NoActionBar_115, + R.style.AppTheme_NoActionBar_120, R.style.AppTheme_NoActionBar_125, + R.style.AppTheme_NoActionBar_130, R.style.AppTheme_NoActionBar_135, + R.style.AppTheme_NoActionBar_140, R.style.AppTheme_NoActionBar_145, + R.style.AppTheme_NoActionBar_150, R.style.AppTheme_NoActionBar_155, + R.style.AppTheme_NoActionBar_160, R.style.AppTheme_NoActionBar_165, + R.style.AppTheme_NoActionBar_170, R.style.AppTheme_NoActionBar_175, + R.style.AppTheme_NoActionBar_180, R.style.AppTheme_NoActionBar_185, + R.style.AppTheme_NoActionBar_190, R.style.AppTheme_NoActionBar_195, + R.style.AppTheme_NoActionBar_200, R.style.AppTheme_NoActionBar_205, + R.style.AppTheme_NoActionBar_210, R.style.AppTheme_NoActionBar_215, + R.style.AppTheme_NoActionBar_220, R.style.AppTheme_NoActionBar_225, + R.style.AppTheme_NoActionBar_230, R.style.AppTheme_NoActionBar_235, + R.style.AppTheme_NoActionBar_240, R.style.AppTheme_NoActionBar_245, + R.style.AppTheme_NoActionBar_250, R.style.AppTheme_NoActionBar_255, + R.style.AppTheme_NoActionBar_260, R.style.AppTheme_NoActionBar_265, + R.style.AppTheme_NoActionBar_270, R.style.AppTheme_NoActionBar_275, + R.style.AppTheme_NoActionBar_280, R.style.AppTheme_NoActionBar_285, + R.style.AppTheme_NoActionBar_290, R.style.AppTheme_NoActionBar_295, + R.style.AppTheme_NoActionBar_300, R.style.AppTheme_NoActionBar_305, + R.style.AppTheme_NoActionBar_310, R.style.AppTheme_NoActionBar_315, + R.style.AppTheme_NoActionBar_320, R.style.AppTheme_NoActionBar_325, + R.style.AppTheme_NoActionBar_330, R.style.AppTheme_NoActionBar_335, + R.style.AppTheme_NoActionBar_340, R.style.AppTheme_NoActionBar_345, + R.style.AppTheme_NoActionBar_350, R.style.AppTheme_NoActionBar_355, + }; public static void refreshColors(Resources.Theme theme) { TypedValue tv = new TypedValue(); theme.resolveAttribute(R.attr.table_row_dark_bg, tv, true); @@ -62,7 +104,7 @@ public class Colors { accent = tv.data; // trigger theme observers - themeWatch.postValue(themeWatch.getValue()+1); + themeWatch.postValue(themeWatch.getValue() + 1); } public static @ColorLong long hsvaColor(float hue, float saturation, float value, float alpha) { @@ -154,7 +196,7 @@ public class Colors { if (y < 0) y += 360; float l = yellowLightness + (blueLightness - yellowLightness) * (float) Math.cos(Math.toRadians(Math.abs(180 - y) / 2f)); - int result = hslColor(hueDegrees/360f, 0.845f, l); + int result = hslColor(hueDegrees / 360f, 0.845f, l); debug("colors", String.format(Locale.ENGLISH, "getPrimaryColorForHue(%d) = %x", hueDegrees, result)); return result; @@ -164,91 +206,46 @@ public class Colors { setupTheme(activity, profile); } public static void setupTheme(Activity activity, MobileLedgerProfile profile) { - final int themeId = (profile == null) ? -1 : profile.getThemeId(); - setupTheme(activity, themeId); + final int themeHue = (profile == null) ? -1 : profile.getThemeId(); + setupTheme(activity, themeHue); } - public static void setupTheme(Activity activity, int themeId) { - switch (themeId) { - case 0: - case 360: - activity.setTheme(R.style.AppTheme_NoActionBar_0); - break; - case 15: - activity.setTheme(R.style.AppTheme_NoActionBar_15); - break; - case 30: - activity.setTheme(R.style.AppTheme_NoActionBar_30); - break; - case 45: - activity.setTheme(R.style.AppTheme_NoActionBar_45); - break; - case 60: - activity.setTheme(R.style.AppTheme_NoActionBar_60); - break; - case 75: - activity.setTheme(R.style.AppTheme_NoActionBar_75); - break; - case 90: - activity.setTheme(R.style.AppTheme_NoActionBar_90); - break; - case 105: - activity.setTheme(R.style.AppTheme_NoActionBar_105); - break; - case 120: - activity.setTheme(R.style.AppTheme_NoActionBar_120); - break; - case 135: - activity.setTheme(R.style.AppTheme_NoActionBar_135); - break; - case 150: - activity.setTheme(R.style.AppTheme_NoActionBar_150); - break; - case 165: - activity.setTheme(R.style.AppTheme_NoActionBar_165); - break; - case 180: - activity.setTheme(R.style.AppTheme_NoActionBar_180); - break; - case 195: - activity.setTheme(R.style.AppTheme_NoActionBar_195); - break; - case 210: - activity.setTheme(R.style.AppTheme_NoActionBar_210); - break; - case 225: - activity.setTheme(R.style.AppTheme_NoActionBar_225); - break; - case 240: - activity.setTheme(R.style.AppTheme_NoActionBar_240); - break; - case 255: - activity.setTheme(R.style.AppTheme_NoActionBar_255); - break; - case 270: - activity.setTheme(R.style.AppTheme_NoActionBar_270); - break; - case 285: - activity.setTheme(R.style.AppTheme_NoActionBar_285); - break; - case 300: - activity.setTheme(R.style.AppTheme_NoActionBar_300); - break; - case 315: - activity.setTheme(R.style.AppTheme_NoActionBar_315); - break; - case 330: - activity.setTheme(R.style.AppTheme_NoActionBar_330); - break; - case 345: - activity.setTheme(R.style.AppTheme_NoActionBar_345); - break; - default: - activity.setTheme(R.style.AppTheme_NoActionBar); - debug("profiles", String.format(Locale.ENGLISH, - "Theme hue %d not supported, using the default", themeId)); + public static void setupTheme(Activity activity, int themeHue) { + int themeId = -1; + // Relies that theme resource IDs are sequential numbers + if (themeHue == 360) themeHue = 0; + if ((themeHue >= 0) && (themeHue < 360) && ((themeHue % HueRing.hueStepDegrees) == 0)) { + themeId = themeIDs[themeHue / HueRing.hueStepDegrees]; + } + + if (themeId < 0) { + activity.setTheme(R.style.AppTheme_NoActionBar); + debug("profiles", + String.format(Locale.ENGLISH, "Theme hue %d not supported, using the default", + themeHue)); + } + else { + activity.setTheme(themeId); } refreshColors(activity.getTheme()); } + public static @NonNull + ColorStateList getColorStateList() { + return getColorStateList(profileThemeId); + } + public static @NonNull + ColorStateList getColorStateList(int hue) { + return new ColorStateList(EMPTY_STATES, getColors(hue)); + } + public static int[] getColors() { + return getColors(profileThemeId); + } + public static int[] getColors(int hue) { + int[] colors = new int[]{0, 0, 0, 0, 0, 0}; + for (int i = 0; i < 6; i++, hue = (hue + 60) % 360) { + colors[i] = getPrimaryColorForHue(hue); + } + return colors; + } }