From 1df231fd6aafa221aef3532d069c7e27d4331be7 Mon Sep 17 00:00:00 2001 From: Linjiajia <319408893@qq.com> Date: 星期日, 27 八月 2023 19:21:01 +0800 Subject: [PATCH] 功能全部完成 --- app/src/main/java/com/application/zhangshi_app_android/adapter/GrowthExperiencePrimaryRvAdapter.java | 115 ++++++++++++++++++++++----------------------------------- 1 files changed, 45 insertions(+), 70 deletions(-) diff --git a/app/src/main/java/com/application/zhangshi_app_android/adapter/GrowthExperiencePrimaryRvAdapter.java b/app/src/main/java/com/application/zhangshi_app_android/adapter/GrowthExperiencePrimaryRvAdapter.java index 3f003b1..e43d1fe 100644 --- a/app/src/main/java/com/application/zhangshi_app_android/adapter/GrowthExperiencePrimaryRvAdapter.java +++ b/app/src/main/java/com/application/zhangshi_app_android/adapter/GrowthExperiencePrimaryRvAdapter.java @@ -14,14 +14,18 @@ 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.GrowthExperienceBean; +import com.application.zhangshi_app_android.bean.TourismBean; import com.application.zhangshi_app_android.databinding.ItemGrowthExperiencePrimaryBinding; import com.application.zhangshi_app_android.ui.function.GrowthExperienceActivity; import com.application.zhangshi_app_android.ui.function.GrowthExperienceActivityViewModel; import java.util.ArrayList; import java.util.Arrays; +import java.util.HashMap; import java.util.List; +import java.util.Map; /** * @author Gss @@ -29,113 +33,84 @@ * @desc 鎴愰暱缁忓巻(涓昏瀛︿範鍙婂伐浣滅粡鍘�) recyclerView 鐨� adapter */ public class GrowthExperiencePrimaryRvAdapter extends BaseRVAdapter<GrowthExperienceBean, ItemGrowthExperiencePrimaryBinding, GrowthExperiencePrimaryRvAdapter.ViewHolder> { + private final Map<GrowthExperienceBean, Boolean> expendMap = new HashMap<>(); - private GrowthExperienceActivityViewModel viewModel; - private List<GrowthExperienceBean> mDataList; - - public GrowthExperiencePrimaryRvAdapter(Context context,List<GrowthExperienceBean> dataList) { + public GrowthExperiencePrimaryRvAdapter(Context context) { super(context); - mDataList = dataList; } - public GrowthExperiencePrimaryRvAdapter(Context context, GrowthExperienceActivityViewModel viewModel) { - super(context); - this.viewModel = viewModel; - } - - public GrowthExperiencePrimaryRvAdapter(GrowthExperienceActivity growthExperienceActivity) { - super(growthExperienceActivity); - } - - public ViewHolder onCreateViewHolder(@NonNull ViewGroup parent, int viewType) { - ItemGrowthExperiencePrimaryBinding itemBind = DataBindingUtil.inflate(LayoutInflater.from(parent.getContext()),getLayoutId(),parent,false); - return new ViewHolder(itemBind); - } @Override protected int getLayoutId() { return R.layout.item_growth_experience_primary; } @Override - protected ViewHolder getViewHolder(ItemGrowthExperiencePrimaryBinding itemBind) { + protected ViewHolder getViewHolder(ItemGrowthExperiencePrimaryBinding itemBind,int viewType) { return new ViewHolder(itemBind); } @Override protected void onBind(ViewHolder holder, int position) { + holder.getBinding().setBean(mDataList.get(position)); + if (position % 2 != 0){ holder.getBinding().cardView.setCardBackgroundColor(mContext.getColor(R.color.color_card_blue)); }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){ - 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(); + holder.getBinding().layoutTitle.setOnClickListener(new View.OnClickListener() { + @Override + public void onClick(View view) { + if (Boolean.TRUE.equals(expendMap.get(getItem(position)))){ + int initialHeight = holder.getBinding().cardView.getMeasuredHeight(); + int collapsedHeight = holder.getBinding().layoutTitle.getMeasuredHeight(); + Utils.pullCollapse(holder.getBinding().cardView,initialHeight,collapsedHeight); + expendMap.put(getItem(position),false); + holder.getBinding().ivFold.setBackgroundResource(R.drawable.ic_fold); + }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); + expendMap.put(getItem(position),true); + holder.getBinding().ivFold.setBackgroundResource(R.drawable.ic_unfold); } - - @Override - public boolean willChangeBounds() { - return true; - } - }; - a.setDuration(500); - holder.getBinding().cardView.startAnimation(a); - holder.isExpended = 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; - } + } + }); } }); - holder.getBinding().layoutContent.setOnClickListener(v -> { - AppManager.getAppManager().startActivity( - new Intent(getRecyclerView().getContext(), GrowthExperienceActivity.class) - .putExtra("bean",mDataList.get(position))); - }); + } public static class ViewHolder extends BaseViewHolder<ItemGrowthExperiencePrimaryBinding>{ private boolean isExpended; - private ItemGrowthExperiencePrimaryBinding binding; public ViewHolder(ItemGrowthExperiencePrimaryBinding binding) { super(binding); - binding=ItemGrowthExperiencePrimaryBinding.inflate(LayoutInflater.from(itemBind.getContext()),(ViewGroup) itemBind,false); } } + } -- Gitblit v1.9.1