From 590c1cff46b105d774271f950caa9f65523f05c1 Mon Sep 17 00:00:00 2001
From: Linjiajia <319408893@qq.com>
Date: 星期五, 29 十二月 2023 20:20:40 +0800
Subject: [PATCH] 1、增加护眼模式主题\n2、修复显示问题

---
 app/src/main/java/com/application/zhangshi_app_android/adapter/ExaminationInfoRvAdapter.java |   23 +++++++++++++++++------
 1 files changed, 17 insertions(+), 6 deletions(-)

diff --git a/app/src/main/java/com/application/zhangshi_app_android/adapter/ExaminationInfoRvAdapter.java b/app/src/main/java/com/application/zhangshi_app_android/adapter/ExaminationInfoRvAdapter.java
index eeb7577..3af721f 100644
--- a/app/src/main/java/com/application/zhangshi_app_android/adapter/ExaminationInfoRvAdapter.java
+++ b/app/src/main/java/com/application/zhangshi_app_android/adapter/ExaminationInfoRvAdapter.java
@@ -2,6 +2,7 @@
 
 import android.content.Context;
 import android.content.Intent;
+import android.util.TypedValue;
 import android.view.View;
 import android.widget.CompoundButton;
 import android.widget.FrameLayout;
@@ -53,22 +54,32 @@
     @Override
     protected void onBind(ViewHolder holder, int position) {
         holder.getBinding().setBean(mDataList.get(position));
+        //鏍规嵁涓婚閫夋嫨瀵瑰簲鍗$墖鑳屾櫙鑹�
+        TypedValue typedValue1 = new TypedValue();
+        mContext.getTheme().resolveAttribute(R.attr.cardBackgroundColorFirst, typedValue1, true);
+        TypedValue typedValue2 = new TypedValue();
+        mContext.getTheme().resolveAttribute(R.attr.cardBackgroundColorSecond, typedValue2, true);
         if (position % 2 != 0){
-            holder.getBinding().cardView.setCardBackgroundColor(mContext.getColor(R.color.color_card_blue));
+            holder.getBinding().cardView.setCardBackgroundColor(typedValue1.data);
         }else {
-            holder.getBinding().cardView.setCardBackgroundColor(mContext.getColor(R.color.color_card_pink));
+            holder.getBinding().cardView.setCardBackgroundColor(typedValue2.data);
         }
         if (!expendMap.containsKey(getItem(position))){
             expendMap.put(getItem(position),false);
         }
+        //鏍规嵁涓婚閫夋嫨瀵瑰簲鍥炬爣
+        TypedValue unfoldIcon = new TypedValue();
+        mContext.getTheme().resolveAttribute(R.attr.icUnfold, unfoldIcon, true);
+        TypedValue foldIcon = new TypedValue();
+        mContext.getTheme().resolveAttribute(R.attr.icFold, foldIcon, true);
         if (Boolean.TRUE.equals(expendMap.get(getItem(position)))){
-            holder.getBinding().ivFold.setBackgroundResource(R.drawable.ic_unfold);
+            holder.getBinding().ivFold.setBackgroundResource(unfoldIcon.resourceId);
             holder.getBinding().cardView.post(() -> {
                 holder.getBinding().cardView.getLayoutParams().height = FrameLayout.LayoutParams.WRAP_CONTENT;
                 holder.getBinding().cardView.requestLayout();
             });
         }else{
-            holder.getBinding().ivFold.setBackgroundResource(R.drawable.ic_fold);
+            holder.getBinding().ivFold.setBackgroundResource(foldIcon.resourceId);
             holder.getBinding().cardView.post(() -> {
                 holder.getBinding().cardView.getLayoutParams().height = holder.getBinding().layoutTitle.getMeasuredHeight();
                 holder.getBinding().cardView.requestLayout();
@@ -104,14 +115,14 @@
                     int initialHeight = holder.getBinding().cardView.getMeasuredHeight();
                     int collapsedHeight = holder.getBinding().layoutTitle.getMeasuredHeight();
                     Utils.pullCollapse(holder.getBinding().cardView,initialHeight,collapsedHeight);
-                    holder.getBinding().ivFold.setBackgroundResource(R.drawable.ic_fold);
+                    holder.getBinding().ivFold.setBackgroundResource(foldIcon.resourceId);
                     expendMap.put(getItem(position),false);
                 }else{
                     final int initialHeight = holder.getBinding().cardView.getMeasuredHeight();
                     holder.getBinding().cardView.measure(FrameLayout.LayoutParams.MATCH_PARENT, FrameLayout.LayoutParams.WRAP_CONTENT);
                     int targetHeight = holder.getBinding().cardView.getMeasuredHeight();
                     Utils.dropExpand(holder.getBinding().cardView,initialHeight,targetHeight);
-                    holder.getBinding().ivFold.setBackgroundResource(R.drawable.ic_unfold);
+                    holder.getBinding().ivFold.setBackgroundResource(unfoldIcon.resourceId);
                     expendMap.put(getItem(position),true);
                 }
             }

--
Gitblit v1.9.1