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/TourismRvAdapter.java | 165 +++++++++++++++++++++++++++++++++++++----------------- 1 files changed, 112 insertions(+), 53 deletions(-) diff --git a/app/src/main/java/com/application/zhangshi_app_android/adapter/TourismRvAdapter.java b/app/src/main/java/com/application/zhangshi_app_android/adapter/TourismRvAdapter.java index 6ab1686..5e1ab0c 100644 --- a/app/src/main/java/com/application/zhangshi_app_android/adapter/TourismRvAdapter.java +++ b/app/src/main/java/com/application/zhangshi_app_android/adapter/TourismRvAdapter.java @@ -3,31 +3,50 @@ import android.content.Context; import android.content.Intent; import android.view.View; -import android.view.animation.Animation; -import android.view.animation.Transformation; +import android.widget.CompoundButton; import android.widget.FrameLayout; +import androidx.recyclerview.widget.GridLayoutManager; + +import com.android.app_base.base.BaseConfig; import com.android.app_base.base.adapter.BaseRVAdapter; +import com.android.app_base.base.dialog.BaseDialog; +import com.android.app_base.base.dialog.UIDialog; 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.DailyConsumeRecordBean; +import com.application.zhangshi_app_android.bean.FamilyMemorabiliaBean; import com.application.zhangshi_app_android.bean.TourismBean; +import com.application.zhangshi_app_android.databinding.ItemFamilyMemorabiliaBinding; import com.application.zhangshi_app_android.databinding.ItemTourismBinding; +import com.application.zhangshi_app_android.ui.function.FamilyMemorabiliaActivityViewModel; +import com.application.zhangshi_app_android.ui.function.FamilyMemorabiliaDetailActivity; +import com.application.zhangshi_app_android.ui.function.TourismActivityViewModel; import com.application.zhangshi_app_android.ui.function.TourismDetailActivity; import com.application.zhangshi_app_android.ui.function.TourismExperienceActivity; +import java.util.ArrayList; +import java.util.HashMap; +import java.util.List; +import java.util.Map; /** * @author Ljj * @date 2023.04.28. 21:18 - * @desc + * @desc 鏃呮父缁忓巻鍒楄〃 Adapter */ public class TourismRvAdapter extends BaseRVAdapter<TourismBean, ItemTourismBinding, TourismRvAdapter.ViewHolder> { - public TourismRvAdapter(Context context) { - super(context); - } + private final TourismActivityViewModel viewModel; + private boolean isCheckable; + private final Map<TourismBean, Boolean> expendMap = new HashMap<>(); + public TourismRvAdapter(Context context, TourismActivityViewModel viewModel) { + super(context); + this.viewModel = viewModel; + } @Override protected int getLayoutId() { return R.layout.item_tourism; @@ -46,76 +65,116 @@ }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(); + }); + } + if (isCheckable){ + holder.getBinding().checkbox.setVisibility(View.VISIBLE); + holder.getBinding().checkbox.setOnCheckedChangeListener(new CompoundButton.OnCheckedChangeListener() { + @Override + public void onCheckedChanged(CompoundButton buttonView, boolean isChecked) { + if (viewModel.getCheckListLiveData().getValue() == null){ + viewModel.getCheckListLiveData().setValue(new ArrayList<>()); + } + List<TourismBean> list = new ArrayList<>(viewModel.getCheckListLiveData().getValue()); + if (isChecked){ + if (!list.contains(mDataList.get(position))){ + list.add(mDataList.get(position)); + } + }else{ + list.remove(mDataList.get(position)); + } + viewModel.getCheckListLiveData().setValue(list); + } + }); + holder.getBinding().checkbox.setChecked(viewModel.getCheckListLiveData().getValue().contains(mDataList.get(position))); + }else{ + holder.getBinding().checkbox.setVisibility(View.GONE); + } 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); } } }); - holder.getBinding().layoutContent.setOnClickListener(v -> { - AppManager.getAppManager().startActivity( - new Intent(getRecyclerView().getContext(), TourismDetailActivity.class) - .putExtra("bean",mDataList.get(position))); + holder.itemView.setOnClickListener(new View.OnClickListener() { + @Override + public void onClick(View v) { + AppManager.getAppManager().startActivity( + new Intent(getRecyclerView().getContext(), TourismDetailActivity.class) + .putExtra(BaseConfig.EXTRA_TYPE,0) + .putExtra("bean",mDataList.get(position))); + } }); - + holder.getBinding().layoutModify.setOnClickListener(new View.OnClickListener() { + @Override + public void onClick(View v) { + AppManager.getAppManager().startActivity( + new Intent(getRecyclerView().getContext(), TourismDetailActivity.class) + .putExtra(BaseConfig.EXTRA_TYPE,2) + .putExtra("bean",mDataList.get(position))); + } + }); + holder.getBinding().layoutDelete.setOnClickListener(new View.OnClickListener() { + @Override + public void onClick(View v) { + new UIDialog.Builder(mContext) + .setTitle("鎮ㄧ‘瀹氳鍒犻櫎璇ラ」鐩悧") + .setContent("椤圭洰鍒犻櫎鍚庡皢鏃犳硶鎭㈠") + .setConfirm("纭畾") + .setCancel("鍙栨秷") + .setListener(new UIDialog.OnListener() { + @Override + public void onConfirm(BaseDialog dialog) { + viewModel.deleteItem(mDataList.get(position)); + } + }) + .show(); + } + }); holder.getBinding().tvDetail.setOnClickListener(new View.OnClickListener() { @Override public void onClick(View v) { AppManager.getAppManager().startActivity( new Intent(getRecyclerView().getContext(), TourismExperienceActivity.class) - .putExtra("bean",mDataList.get(position))); + .putExtra("id",mDataList.get(position).getId())); } }); - } - public static class ViewHolder extends BaseRVAdapter.BaseViewHolder<ItemTourismBinding> { - private boolean isExpended; + public void setCheckable(boolean b) { + isCheckable = b; + notifyItemRangeChanged(0,getItemCount()); + } + + public static class ViewHolder extends BaseViewHolder<ItemTourismBinding>{ public ViewHolder(ItemTourismBinding binding) { super(binding); } -- Gitblit v1.9.1