From 5325e22a184b53aadcc5e9552cb1ec54f9c8ad81 Mon Sep 17 00:00:00 2001
From: guoshen <3129367635@qq.com>
Date: 星期六, 29 六月 2024 16:33:11 +0800
Subject: [PATCH] 加入了直播、会议功能

---
 app/src/main/java/com/application/zhangshi_app_android/adapter/FamilyMemorabiliaRvAdapter.java |   72 +++++++++++++++++++++++++++++++++--
 1 files changed, 67 insertions(+), 5 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 cbcba39..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
@@ -4,8 +4,6 @@
 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;
 
@@ -19,10 +17,9 @@
 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.bean.TourismBean;
 import com.application.zhangshi_app_android.databinding.ItemFamilyMemorabiliaBinding;
-import com.application.zhangshi_app_android.ui.function.FamilyMemorabiliaDetailActivity;
 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.HashMap;
@@ -40,46 +37,67 @@
     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(typedValue1.data);
         }else {
             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(() -> {
@@ -93,6 +111,9 @@
                 holder.getBinding().cardView.requestLayout();
             });
         }
+
+
+        //杩欐浠g爜鐨勪綔鐢ㄦ槸鏍规嵁鏉′欢鏄剧ず鎴栭殣钘忓閫夋锛屽苟鍦ㄧ敤鎴烽�夋嫨鍒楄〃椤规椂鏇存柊鐩稿簲鐨� LiveData 鏁版嵁浠ュ強鐣岄潰涓婄殑澶嶉�夋鐘舵��
         if (isCheckable){
             holder.getBinding().ivFlower.setVisibility(View.GONE);
             if (mDataList.get(position).getOwnData() == 1){
@@ -100,6 +121,8 @@
             }else {
                 holder.getBinding().checkbox.setVisibility(View.GONE);
             }
+
+
             holder.getBinding().checkbox.setOnCheckedChangeListener(new CompoundButton.OnCheckedChangeListener() {
                 @Override
                 public void onCheckedChanged(CompoundButton buttonView, boolean isChecked) {
@@ -126,43 +149,71 @@
                 holder.getBinding().ivFlower.setVisibility(View.GONE);
             }
         }
+
+
+
+
         holder.getBinding().layoutTitle.setOnClickListener(new View.OnClickListener() {
             @Override
             public void onClick(View view) {
+                //濡傛灉expendMap 涓瓨鍌ㄧ殑褰撳墠浣嶇疆鐨勭姸鎬佹槸 true锛岃〃绀哄綋鍓嶈鍥炬槸灞曞紑鐘舵�侊紝闇�瑕佹墽琛屾姌鍙犳搷浣滐細
                 if (Boolean.TRUE.equals(expendMap.get(getItem(position)))){
+
+                    //鑾峰彇鍗$墖瑙嗗浘鐨勫垵濮嬮珮搴�
                     int initialHeight = holder.getBinding().cardView.getMeasuredHeight();
+                    //鑾峰彇鏍囬甯冨眬鐨勯珮搴︺��
                     int collapsedHeight = holder.getBinding().layoutTitle.getMeasuredHeight();
+
+                    //璋冪敤 Utils.pullCollapse() 鏂规硶鎵ц鎶樺彔鍔ㄧ敾锛屽苟浼犲叆鍗$墖瑙嗗浘鐨勫垵濮嬮珮搴﹀拰鏍囬甯冨眬鐨勯珮搴︺��
                     Utils.pullCollapse(holder.getBinding().cardView,initialHeight,collapsedHeight);
                     holder.getBinding().ivFold.setBackgroundResource(foldIcon.resourceId);
+
+                    //灏嗙姸鎬佽缃负鎶樺彔
                     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();
+                    //璋冪敤 Utils.dropExpand() 鏂规硶鎵ц灞曞紑鍔ㄧ敾锛屽苟浼犲叆鍗$墖瑙嗗浘鐨勫垵濮嬮珮搴﹀拰鐩爣楂樺害銆�
                     Utils.dropExpand(holder.getBinding().cardView,initialHeight,targetHeight);
+                    //鏇存柊鎶樺彔鍥炬爣涓哄睍寮�鐘舵�併��
                     holder.getBinding().ivFold.setBackgroundResource(unfoldIcon.resourceId);
                     expendMap.put(getItem(position),true);
                 }
             }
         });
+
+        //璁剧疆鐩戝惉浜嬩欢锛屽綋鐢ㄦ埛鐐瑰嚮holder.itemView鏃讹紝鎵ц涓嬮潰鎿嶄綔
         holder.itemView.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,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) {
@@ -180,12 +231,23 @@
                         .show();
             }
         });
+
+
+        //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());

--
Gitblit v1.9.1