From a47aa2ebb05eca5efc3ad4f7c9c2841131c1b36b Mon Sep 17 00:00:00 2001 From: mueller-ma Date: Thu, 18 Jul 2024 20:20:34 +0200 Subject: [PATCH] Improve skeleton colors Signed-off-by: mueller-ma --- .../java/org/openhab/habdroid/ui/widget/WidgetImageView.kt | 7 ++++++- mobile/src/main/res/layout/activity_chart.xml | 3 ++- mobile/src/main/res/layout/activity_image.xml | 3 ++- mobile/src/main/res/layout/fragment_notificationlist.xml | 3 ++- mobile/src/main/res/values-night/themes.xml | 2 ++ mobile/src/main/res/values/attrs.xml | 2 ++ mobile/src/main/res/values/themes.xml | 2 ++ 7 files changed, 18 insertions(+), 4 deletions(-) diff --git a/mobile/src/main/java/org/openhab/habdroid/ui/widget/WidgetImageView.kt b/mobile/src/main/java/org/openhab/habdroid/ui/widget/WidgetImageView.kt index 68233d79d0..09bc702246 100644 --- a/mobile/src/main/java/org/openhab/habdroid/ui/widget/WidgetImageView.kt +++ b/mobile/src/main/java/org/openhab/habdroid/ui/widget/WidgetImageView.kt @@ -23,6 +23,7 @@ import android.util.Base64 import android.util.Log import androidx.appcompat.widget.AppCompatImageView import com.faltenreich.skeletonlayout.Skeleton +import com.faltenreich.skeletonlayout.SkeletonConfig import com.faltenreich.skeletonlayout.SkeletonLayout import com.faltenreich.skeletonlayout.createSkeleton import kotlin.random.Random @@ -42,6 +43,7 @@ import org.openhab.habdroid.util.ImageConversionPolicy import org.openhab.habdroid.util.getIconFallbackColor import org.openhab.habdroid.util.getPrefs import org.openhab.habdroid.util.isDebugModeEnabled +import org.openhab.habdroid.util.resolveThemedColor class WidgetImageView(context: Context, attrs: AttributeSet?) : AppCompatImageView(context, attrs) { private var scope: CoroutineScope? = null @@ -317,7 +319,10 @@ class WidgetImageView(context: Context, attrs: AttributeSet?) : AppCompatImageVi private fun applySkeleton() { if (skeleton == null) { - skeleton = createSkeleton() + val config = SkeletonConfig.default(context) + config.maskColor = context.resolveThemedColor(R.attr.skeletonBackground, config.maskColor) + config.shimmerColor = context.resolveThemedColor(R.attr.skeletonShimmer, config.shimmerColor) + skeleton = createSkeleton(config) } skeleton?.showSkeleton() } diff --git a/mobile/src/main/res/layout/activity_chart.xml b/mobile/src/main/res/layout/activity_chart.xml index ae1bd79077..c0bad332d1 100644 --- a/mobile/src/main/res/layout/activity_chart.xml +++ b/mobile/src/main/res/layout/activity_chart.xml @@ -18,7 +18,8 @@ + app:maskColor="?skeletonBackground" + app:shimmerColor="?skeletonShimmer"> + app:maskColor="?skeletonBackground" + app:shimmerColor="?skeletonShimmer"> + app:maskColor="?skeletonBackground" + app:shimmerColor="?skeletonShimmer"> @array/valueColorsDarkBackground ?android:colorBackground false + #1E1E1E + #3C3C3C