From 82e57df230ecb744af6c8865f80870ba03c86d89 Mon Sep 17 00:00:00 2001
From: Linjiajia <319408893@qq.com>
Date: 星期二, 25 七月 2023 22:18:27 +0800
Subject: [PATCH] 基本功能完成

---
 app/src/main/java/com/application/zhangshi_app_android/adapter/HundredWishRvAdapter.java |   88 +++++++++++++++++---------------------------
 1 files changed, 34 insertions(+), 54 deletions(-)

diff --git a/app/src/main/java/com/application/zhangshi_app_android/adapter/HundredWishRvAdapter.java b/app/src/main/java/com/application/zhangshi_app_android/adapter/HundredWishRvAdapter.java
index 633aac0..01eb0fd 100644
--- a/app/src/main/java/com/application/zhangshi_app_android/adapter/HundredWishRvAdapter.java
+++ b/app/src/main/java/com/application/zhangshi_app_android/adapter/HundredWishRvAdapter.java
@@ -11,20 +11,27 @@
 
 import com.android.app_base.base.adapter.BaseRVAdapter;
 import com.android.app_base.manager.AppManager;
+import com.android.app_base.utils.Utils;
 import com.application.zhangshi_app_android.R;
 import com.application.zhangshi_app_android.bean.HundredWishBean;
+import com.application.zhangshi_app_android.bean.TourismBean;
 import com.application.zhangshi_app_android.databinding.ItemHundredWishBinding;
 import com.application.zhangshi_app_android.ui.function.HundredWishDetailActivity;
+import com.application.zhangshi_app_android.ui.function.PropertyDetailActivity;
 
 import java.util.ArrayList;
 import java.util.Arrays;
+import java.util.HashMap;
 import java.util.List;
+import java.util.Map;
 
 /**
 * @author Ljj
 * @date 2023.04.23. 20:05
 * @desc
 */public class HundredWishRvAdapter extends BaseRVAdapter<HundredWishBean, ItemHundredWishBinding, HundredWishRvAdapter.ViewHolder> {
+    private final Map<HundredWishBean, Boolean> expendMap = new HashMap<>();
+
     public HundredWishRvAdapter(Context context) {
         super(context);
     }
@@ -47,53 +54,38 @@
         }else {
             holder.getBinding().cardView.setCardBackgroundColor(mContext.getColor(R.color.color_card_pink));
         }
+        if (!expendMap.containsKey(getItem(position))){
+            expendMap.put(getItem(position),false);
+        }
+        if (Boolean.TRUE.equals(expendMap.get(getItem(position)))){
+            holder.getBinding().ivFold.setBackgroundResource(R.drawable.ic_unfold);
+            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().cardView.post(() -> {
+                holder.getBinding().cardView.getLayoutParams().height = holder.getBinding().layoutTitle.getMeasuredHeight();
+                holder.getBinding().cardView.requestLayout();
+            });
+        }
         holder.getBinding().layoutTitle.setOnClickListener(new View.OnClickListener() {
             @Override
             public void onClick(View view) {
-                if (holder.isExpended){
+                if (Boolean.TRUE.equals(expendMap.get(getItem(position)))){
                     int initialHeight = holder.getBinding().cardView.getMeasuredHeight();
                     int collapsedHeight = holder.getBinding().layoutTitle.getMeasuredHeight();
-                    int distanceToCollapse = (int) (initialHeight - collapsedHeight);
-
-                    Animation a = new Animation() {
-                        @Override
-                        protected void applyTransformation(float interpolatedTime, Transformation t) {
-                            if (interpolatedTime == 1){
-                            }
-                            holder.getBinding().cardView.getLayoutParams().height = (int) (initialHeight - (distanceToCollapse * interpolatedTime));
-                            holder.getBinding().cardView.requestLayout();
-                        }
-
-                        @Override
-                        public boolean willChangeBounds() {
-                            return true;
-                        }
-                    };
-                    a.setDuration(500);
-                    holder.getBinding().cardView.startAnimation(a);
-                    holder.isExpended = false;
+                    Utils.pullCollapse(holder.getBinding().cardView,initialHeight,collapsedHeight);
+                    holder.getBinding().ivFold.setBackgroundResource(R.drawable.ic_fold);
+                    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();
-                    int distanceToExpand = targetHeight - initialHeight;
-                    Animation a = new Animation() {
-                        @Override
-                        protected void applyTransformation(float interpolatedTime, Transformation t) {
-                            if (interpolatedTime == 1){
-                            }
-                            holder.getBinding().cardView.getLayoutParams().height = (int) (initialHeight + (distanceToExpand * interpolatedTime));
-                            holder.getBinding().cardView.requestLayout();
-                        }
-
-                        @Override
-                        public boolean willChangeBounds() {
-                            return true;
-                        }
-                    };
-                    a.setDuration(500);
-                    holder.getBinding().cardView.startAnimation(a);
-                    holder.isExpended = true;
+                    Utils.dropExpand(holder.getBinding().cardView,initialHeight,targetHeight);
+                    holder.getBinding().ivFold.setBackgroundResource(R.drawable.ic_unfold);
+                    expendMap.put(getItem(position),true);
                 }
             }
         });
@@ -102,27 +94,15 @@
                     new Intent(getRecyclerView().getContext(), HundredWishDetailActivity.class)
                             .putExtra("bean",mDataList.get(position)));
         });
-
-        ImageRvAdapter adapter = new ImageRvAdapter(mContext);
+        ElectronicFileAdapter adapter = new ElectronicFileAdapter(mContext);
         holder.getBinding().rvImage.setLayoutManager(new GridLayoutManager(mContext,3));
         holder.getBinding().rvImage.setAdapter(adapter);
-        String url = mDataList.get(position).getUrl();
-        if (url == null||url.isEmpty()){
-            return;
-        }
-        List<String> list;
-        if (url.contains(",")){
-            String[] split = url.split(",");
-            list = new ArrayList<>(Arrays.asList(split));
-        }else {
-            list = new ArrayList<>();
-            list.add(url);
-        }
-        adapter.setData(list);
+        adapter.setData(Utils.splitString2List(mDataList.get(position).getUrl(),","));
+
+
     }
 
     public static class ViewHolder extends BaseRVAdapter.BaseViewHolder<ItemHundredWishBinding> {
-        private boolean isExpended;
 
         public ViewHolder(ItemHundredWishBinding binding) {
             super(binding);

--
Gitblit v1.9.1