From 596d0bcbacd8dde70f0bbcfdf07db5cf694220ef Mon Sep 17 00:00:00 2001
From: zuoxiao <470321431@qq.com>
Date: 星期三, 08 一月 2025 09:33:20 +0800
Subject: [PATCH] 1.修复上传文件取消上传还会上传bug 2.添加上传视频功能 3.添加关闭activity时关闭上传功能。

---
 app/src/main/java/com/dayu/pipirrapp/adapter/AddPictureAdapter.java |   46 ++++++++++++++++++++++++++--------------------
 1 files changed, 26 insertions(+), 20 deletions(-)

diff --git a/app/src/main/java/com/dayu/pipirrapp/adapter/AddPictureAdapter.java b/app/src/main/java/com/dayu/pipirrapp/adapter/AddPictureAdapter.java
index 71b52a3..7302fde 100644
--- a/app/src/main/java/com/dayu/pipirrapp/adapter/AddPictureAdapter.java
+++ b/app/src/main/java/com/dayu/pipirrapp/adapter/AddPictureAdapter.java
@@ -122,6 +122,7 @@
             });
             viewHolder.mIvDel.setVisibility(View.INVISIBLE);
             viewHolder.circleProgressView.setVisibility(View.GONE);
+            viewHolder.maskLayerBg.setVisibility(View.GONE);
         } else {
             //鍒犻櫎鍥剧墖
             viewHolder.mIvDel.setVisibility(View.VISIBLE);
@@ -163,19 +164,16 @@
             }
 
             // 鏇存柊杩涘害
-            UplodFileState uplodFileState;
-            if (TextUtils.isEmpty(media.getCompressPath())) {
-                uplodFileState = fileStates.get(media.getRealPath());
-            } else {
-                uplodFileState = fileStates.get(media.getCompressPath());
-            }
-
-
+            UplodFileState uplodFileState = TextUtils.isEmpty(media.getCompressPath())
+                    ? fileStates.get(media.getRealPath())
+                    : fileStates.get(media.getCompressPath());
             if (uplodFileState != null) {
                 uplodFileState.setAdapterPosition(position);
                 MyLog.d("progressRequestBodyHolder>>>" + "State:" + uplodFileState.getState() + ">>>position:" + position + ">>>Progress: " + uplodFileState.getProgress());
 
                 if (uplodFileState.getState() == UplodFileState.STATE_UPDING) {
+                    MyLog.d("progressRequestBodyHolder>>>" + "姝e湪涓婁紶");
+                    viewHolder.postError.setVisibility(View.GONE);
                     if (uplodFileState.getProgress() < 100) {
                         viewHolder.maskLayerBg.setVisibility(View.VISIBLE);
                         viewHolder.circleProgressView.setVisibility(View.VISIBLE);
@@ -185,10 +183,12 @@
                         viewHolder.circleProgressView.setVisibility(View.GONE);
                         viewHolder.maskLayerBg.setVisibility(View.GONE);
                     }
-                } else if (fileStates.get(media.getCompressPath()).getState() == UplodFileState.STATE_DONE) {
+                } else if (uplodFileState.getState() == UplodFileState.STATE_DONE) {
+                    MyLog.d("progressRequestBodyHolder>>>" + "瀹屾垚");
                     viewHolder.maskLayerBg.setVisibility(View.GONE);
                     viewHolder.circleProgressView.setVisibility(View.GONE);
                 } else {
+                    MyLog.d("progressRequestBodyHolder>>>" + "閿欒");
                     viewHolder.maskLayerBg.setVisibility(View.VISIBLE);
                     viewHolder.postError.setVisibility(View.VISIBLE);
                     viewHolder.circleProgressView.setVisibility(View.GONE);
@@ -202,11 +202,14 @@
                     int adapterPosition = viewHolder.getAbsoluteAdapterPosition();
                     mItemClickListener.onItemClick(v, adapterPosition);
                 });
+                viewHolder.postError.setOnClickListener(v -> {
+                    mItemClickListener.onReUpload(uplodFileState);
+                });
             }
 
             if (mItemLongClickListener != null) {
                 viewHolder.itemView.setOnLongClickListener(v -> {
-                    int adapterPosition = viewHolder.getAbsoluteAdapterPosition();
+                    int adapterPosition = viewHolder.getBindingAdapterPosition();
                     mItemLongClickListener.onItemLongClick(viewHolder, adapterPosition, v);
                     return true;
                 });
@@ -224,20 +227,18 @@
 
         // 鏇存柊杩涘害鍙傛暟
         if (fileStates.containsKey(uplodFileState.getFilePath())) {
+            // 鑾峰彇宸叉湁鐨� UplodFileState 瀵硅薄骞舵洿鏂拌繘搴�
+            UplodFileState existingState = fileStates.get(uplodFileState.getFilePath());
+            int position = existingState.getAdapterPosition();
+            existingState.setState(uplodFileState.getState());
             if (uplodFileState.getState() == 0) {
-                // 鑾峰彇宸叉湁鐨� UplodFileState 瀵硅薄骞舵洿鏂拌繘搴�
-                UplodFileState existingState = fileStates.get(uplodFileState.getFilePath());
+                existingState.setState(uplodFileState.getState());
                 existingState.setProgress(uplodFileState.getProgress()); // 鏇存柊杩涘害
                 // 鑾峰彇杩涘害鏇存柊椤圭殑浣嶇疆
-                int position = existingState.getAdapterPosition();
-                if (position != RecyclerView.NO_POSITION) {
-                    // 閫氱煡閫傞厤鍣ㄥ埛鏂版寚瀹氫綅缃殑椤�
-                    notifyItemChanged(position);
-                }
-            } else if (uplodFileState.getState() == 2) {
-
             }
-
+            if (position != RecyclerView.NO_POSITION) {
+                notifyItemChanged(position);
+            }
         }
     }
 
@@ -267,6 +268,11 @@
          * @param position
          */
         void onDeleteClick(int position);
+
+        /**
+         * 涓婁紶澶辫触鍚庨噸鏂颁笂浼�
+         */
+        void onReUpload(UplodFileState uplodFileState);
     }
 
     private OnItemLongClickListener mItemLongClickListener;

--
Gitblit v1.8.0