From 42ea59771a54d2591df0a6dd3936dda669be99ae Mon Sep 17 00:00:00 2001 From: gs <3129367635@qq.com> Date: 星期一, 08 七月 2024 12:23:48 +0800 Subject: [PATCH] 会议统计接入增加,删除,修改接口 --- app/src/main/java/com/application/zhangshi_app_android/adapter/FamilyMemorabiliaRvAdapter.java | 199 +++++++++++++++++++++++++++++++++++-------------- 1 files changed, 142 insertions(+), 57 deletions(-) diff --git a/app/src/main/java/com/application/zhangshi_app_android/adapter/FamilyMemorabiliaRvAdapter.java b/app/src/main/java/com/application/zhangshi_app_android/adapter/FamilyMemorabiliaRvAdapter.java index 3633bbd..fe81aff 100644 --- a/app/src/main/java/com/application/zhangshi_app_android/adapter/FamilyMemorabiliaRvAdapter.java +++ b/app/src/main/java/com/application/zhangshi_app_android/adapter/FamilyMemorabiliaRvAdapter.java @@ -2,31 +2,29 @@ import android.content.Context; import android.content.Intent; +import android.util.TypedValue; import android.view.View; -import android.view.animation.Animation; -import android.view.animation.Transformation; import android.widget.CompoundButton; import android.widget.FrameLayout; -import androidx.lifecycle.LiveData; -import androidx.lifecycle.MutableLiveData; 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.FamilyMemorabiliaBean; import com.application.zhangshi_app_android.databinding.ItemFamilyMemorabiliaBinding; -import com.application.zhangshi_app_android.ui.function.CreateFamilyProjectActivity; -import com.application.zhangshi_app_android.ui.function.FamilyMemorabiliaActivity; import com.application.zhangshi_app_android.ui.function.FamilyMemorabiliaActivityViewModel; +import com.application.zhangshi_app_android.ui.function.FamilyMemorabiliaDetailActivity; import java.util.ArrayList; -import java.util.Collection; -import java.util.Collections; +import java.util.HashMap; import java.util.List; -import java.util.Objects; +import java.util.Map; /** * @author Ljj @@ -35,39 +33,96 @@ */ public class FamilyMemorabiliaRvAdapter extends BaseRVAdapter<FamilyMemorabiliaBean, ItemFamilyMemorabiliaBinding, FamilyMemorabiliaRvAdapter.MyViewHolder> { - private FamilyMemorabiliaActivityViewModel viewModel; + private final Map<FamilyMemorabiliaBean, Boolean> expendMap = new HashMap<>(); private boolean isCheckable; + + //鎺ュ彈涓�涓笂涓嬫枃鍙傛暟锛岀敤浜庡垵濮嬪寲鍑芥暟 public FamilyMemorabiliaRvAdapter(Context context) { super(context); } + //闄や簡涓婁笅鏂囧弬鏁板锛岃繕鎺ュ彈涓�涓獀iew Model瀵硅薄浣滀负鍙傛暟锛岀敤浜庝笌瑙嗗浘妯″瀷杩涜浜や簰鍜屾暟鎹粦瀹� public FamilyMemorabiliaRvAdapter(Context context, FamilyMemorabiliaActivityViewModel viewModel) { super(context); this.viewModel = viewModel; } + + //缁戝畾item瑙嗗浘 @Override protected int getLayoutId() { return R.layout.item_family_memorabilia; } + //鍒涘缓瑙嗗浘鎸佹湁鑰呭璞″苟杩斿洖锛岀敤浜庣粦瀹氳鍥惧拰鏁版嵁 @Override protected MyViewHolder getViewHolder(ItemFamilyMemorabiliaBinding itemBind,int viewType) { return new MyViewHolder(itemBind); } + + //onBind() @Override protected void onBind(MyViewHolder holder, int position) { + //灏嗗綋鍓嶄綅缃殑鏁版嵁缁戝畾鍒拌鍥炬寔鏈夎�呬腑鐨勫竷灞�缁戝畾瀵硅薄涓婏紝浠ヤ究鏄剧ず鐩稿簲鐨勫搴邯蹇靛搧鏁版嵁銆� holder.getBinding().setBean(mDataList.get(position)); + + //typeValue1 瀛樺偍瑙f瀽鍚庣殑灞炴�у�� + TypedValue typedValue1 = new TypedValue(); + + // + mContext.getTheme().resolveAttribute(R.attr.cardBackgroundColorFirst, typedValue1, true); + TypedValue typedValue2 = new TypedValue(); + mContext.getTheme().resolveAttribute(R.attr.cardBackgroundColorSecond, typedValue2, true); + //position涓哄鏁扮殑鏃跺�欙紝鐢╰ypedValue1浣滀负鑳屾櫙鑹诧紝鍋舵暟鏃剁敤typedValue2銆� 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); } + + //expendMap 鏄竴涓敤浜庡瓨鍌ㄥ垪琛ㄩ」灞曞紑鐘舵�佺殑 Map锛� + // 杩欓噷鐢ㄦ潵妫�鏌ュ綋鍓嶄綅缃搴旂殑鏁版嵁鏄惁宸茬粡鍦� Map 涓瓨鍦紝 + // 濡傛灉涓嶅瓨鍦紝鍒欏皢鍏舵坊鍔犲埌 Map 涓紝骞惰缃叾灞曞紑鐘舵�佷负 false銆� + 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(unfoldIcon.resourceId); + holder.getBinding().cardView.post(() -> { + holder.getBinding().cardView.getLayoutParams().height = FrameLayout.LayoutParams.WRAP_CONTENT; + holder.getBinding().cardView.requestLayout(); + }); + }else{ + holder.getBinding().ivFold.setBackgroundResource(foldIcon.resourceId); + holder.getBinding().cardView.post(() -> { + holder.getBinding().cardView.getLayoutParams().height = holder.getBinding().layoutTitle.getMeasuredHeight(); + holder.getBinding().cardView.requestLayout(); + }); + } + + + //杩欐浠g爜鐨勪綔鐢ㄦ槸鏍规嵁鏉′欢鏄剧ず鎴栭殣钘忓閫夋锛屽苟鍦ㄧ敤鎴烽�夋嫨鍒楄〃椤规椂鏇存柊鐩稿簲鐨� LiveData 鏁版嵁浠ュ強鐣岄潰涓婄殑澶嶉�夋鐘舵�� if (isCheckable){ - holder.getBinding().checkbox.setVisibility(View.VISIBLE); + holder.getBinding().ivFlower.setVisibility(View.GONE); + if (mDataList.get(position).getOwnData() == 1){ + holder.getBinding().checkbox.setVisibility(View.VISIBLE); + }else { + holder.getBinding().checkbox.setVisibility(View.GONE); + } + + holder.getBinding().checkbox.setOnCheckedChangeListener(new CompoundButton.OnCheckedChangeListener() { @Override public void onCheckedChanged(CompoundButton buttonView, boolean isChecked) { @@ -88,79 +143,111 @@ holder.getBinding().checkbox.setChecked(viewModel.getCheckListLiveData().getValue().contains(mDataList.get(position))); }else{ holder.getBinding().checkbox.setVisibility(View.GONE); + if (mDataList.get(position).getOwnData() == 1){ + holder.getBinding().ivFlower.setVisibility(View.VISIBLE); + }else { + holder.getBinding().ivFlower.setVisibility(View.GONE); + } } + + + + holder.getBinding().layoutTitle.setOnClickListener(new View.OnClickListener() { @Override public void onClick(View view) { - if (holder.isExpended){ + //濡傛灉expendMap 涓瓨鍌ㄧ殑褰撳墠浣嶇疆鐨勭姸鎬佹槸 true锛岃〃绀哄綋鍓嶈鍥炬槸灞曞紑鐘舵�侊紝闇�瑕佹墽琛屾姌鍙犳搷浣滐細 + 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(); - } + //璋冪敤 Utils.pullCollapse() 鏂规硶鎵ц鎶樺彔鍔ㄧ敾锛屽苟浼犲叆鍗$墖瑙嗗浘鐨勫垵濮嬮珮搴﹀拰鏍囬甯冨眬鐨勯珮搴︺�� + Utils.pullCollapse(holder.getBinding().cardView,initialHeight,collapsedHeight); + holder.getBinding().ivFold.setBackgroundResource(foldIcon.resourceId); - @Override - public boolean willChangeBounds() { - return true; - } - }; - a.setDuration(500); - holder.getBinding().cardView.startAnimation(a); - holder.isExpended = false; + //灏嗙姸鎬佽缃负鎶樺彔 + expendMap.put(getItem(position),false); }else{ + //鑾峰彇鍗$墖瑙嗗浘鐨勫垵濮嬮珮搴� initialHeight銆� final int initialHeight = holder.getBinding().cardView.getMeasuredHeight(); + //娴嬮噺鍗$墖瑙嗗浘鐨勭洰鏍囬珮搴� targetHeight 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() 鏂规硶鎵ц灞曞紑鍔ㄧ敾锛屽苟浼犲叆鍗$墖瑙嗗浘鐨勫垵濮嬮珮搴﹀拰鐩爣楂樺害銆� + Utils.dropExpand(holder.getBinding().cardView,initialHeight,targetHeight); + //鏇存柊鎶樺彔鍥炬爣涓哄睍寮�鐘舵�併�� + holder.getBinding().ivFold.setBackgroundResource(unfoldIcon.resourceId); + expendMap.put(getItem(position),true); } } }); - holder.getBinding().layoutModify.setOnClickListener(new View.OnClickListener() { + + //璁剧疆鐩戝惉浜嬩欢锛屽綋鐢ㄦ埛鐐瑰嚮holder.itemView鏃讹紝鎵ц涓嬮潰鎿嶄綔 + holder.itemView.setOnClickListener(new View.OnClickListener() { @Override public void onClick(View v) { + //鍒涘缓涓�涓柊鐨� Intent 瀵硅薄锛岃瀵硅薄鐢ㄤ簬鍚姩 FamilyMemorabiliaDetailActivity 娲诲姩銆� + + AppManager.getAppManager().startActivity( - new Intent(getRecyclerView().getContext(), CreateFamilyProjectActivity.class) + new Intent(getRecyclerView().getContext(), FamilyMemorabiliaDetailActivity.class) .putExtra(BaseConfig.EXTRA_TYPE,0) .putExtra("bean",mDataList.get(position))); } }); + + + //璁剧疆鐩戝惉浜嬩欢锛屽綋鐢ㄦ埛鐐瑰嚮layout涓搴旂殑layout_modify鏃讹紝鎵ц涓嬮潰鎿嶄綔 + holder.getBinding().layoutModify.setOnClickListener(new View.OnClickListener() { + @Override + public void onClick(View v) { + //鍒涘缓涓�涓柊鐨� Intent 瀵硅薄锛岃瀵硅薄鐢ㄤ簬鍚姩 FamilyMemorabiliaDetailActivity 娲诲姩銆� + AppManager.getAppManager().startActivity( + new Intent(getRecyclerView().getContext(), FamilyMemorabiliaDetailActivity.class) + .putExtra(BaseConfig.EXTRA_TYPE,2) + .putExtra("bean",mDataList.get(position))); + } + }); + + + //璁剧疆鐩戝惉浜嬩欢锛屽綋鐢ㄦ埛鐐瑰嚮layout涓搴旂殑layout_delete鏃讹紝鎵ц涓嬮潰鎿嶄綔 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(); } }); - ImageRvAdapter adapter = new ImageRvAdapter(mContext); - mDataList.get(position).setUrl(mDataList.get(position).getUrl()); - adapter.setData(mDataList.get(position).getUrlList()); + + + //ElectronicFileAdapter 閫傞厤鍣ㄦ潵鏄剧ず鐢靛瓙鏂囦欢鍒楄〃锛屽苟灏嗗叾缁戝畾鍒� 瑙嗗浘layout涓殑rv_image + ElectronicFileAdapter adapter = new ElectronicFileAdapter(mContext); + adapter.setData(Utils.splitString2List(mDataList.get(position).getUrl(),",")); holder.getBinding().rvImage.setLayoutManager(new GridLayoutManager(mContext,3)); holder.getBinding().rvImage.setAdapter(adapter); } + + + + + + + + //notifyItemRangeChanged(0, getItemCount()) 鏂规硶锛岄�氱煡閫傞厤鍣ㄨ寖鍥村唴鐨勯」宸叉洿鏀癸紝浠ヤ究鍦� RecyclerView 涓洿鏂扮浉搴旂殑瑙嗗浘銆� public void setCheckable(boolean b) { isCheckable = b; notifyItemRangeChanged(0,getItemCount()); @@ -168,8 +255,6 @@ public static class MyViewHolder extends BaseViewHolder<ItemFamilyMemorabiliaBinding>{ - private boolean isExpended; - public MyViewHolder(ItemFamilyMemorabiliaBinding binding) { super(binding); } -- Gitblit v1.9.1