From ec6193939600ca7930193b1d5942b1700baf9e06 Mon Sep 17 00:00:00 2001
From: zuoxiao <470321431@qq.com>
Date: 星期五, 21 二月 2025 09:20:15 +0800
Subject: [PATCH] 1.巡检记录列表页的实现 2.巡检记录地图展示路径的详情页。 3.处理巡检记录详情页因打开同一个网址导致的webView不显示问题。 4.实现地图页搜索后的地图跳转功能。 5.巡检记录详情页数据加载的优化,默认加载本地数据,当本地没有数据时从服务端获取数据。

---
 app/src/main/java/com/dayu/pipirrapp/net/ApiManager.java |  150 +++++++++++++++++++++++++++++++------------------
 1 files changed, 94 insertions(+), 56 deletions(-)

diff --git a/app/src/main/java/com/dayu/pipirrapp/net/ApiManager.java b/app/src/main/java/com/dayu/pipirrapp/net/ApiManager.java
index d0d399a..e21da6e 100644
--- a/app/src/main/java/com/dayu/pipirrapp/net/ApiManager.java
+++ b/app/src/main/java/com/dayu/pipirrapp/net/ApiManager.java
@@ -1,5 +1,8 @@
 package com.dayu.pipirrapp.net;
 
+import static com.dayu.pipirrapp.bean.net.UplodFileState.STATE_DONE;
+import static com.dayu.pipirrapp.bean.net.UplodFileState.STATE_ERROR;
+import static com.dayu.pipirrapp.bean.net.UplodFileState.STATE_UPDING;
 import static com.luck.picture.lib.thread.PictureThreadUtils.runOnUiThread;
 
 import android.annotation.SuppressLint;
@@ -14,12 +17,11 @@
 import com.dayu.pipirrapp.bean.net.CodeResult;
 import com.dayu.pipirrapp.bean.net.UplodFileState;
 import com.dayu.pipirrapp.bean.net.WeatherResponse;
+import com.dayu.pipirrapp.bean.net.UploadFileResult;
 import com.dayu.pipirrapp.net.subscribers.BaseProgressSubscriber;
 import com.dayu.pipirrapp.net.subscribers.CodeListener;
 import com.dayu.pipirrapp.net.subscribers.ProgressSubscriber;
 import com.dayu.pipirrapp.net.subscribers.SubscriberListener;
-import com.dayu.pipirrapp.net.upload.IMGProgressLisener;
-import com.dayu.pipirrapp.net.upload.ProgressListener;
 import com.dayu.pipirrapp.net.upload.ProgressRequestBody;
 import com.dayu.pipirrapp.net.upload.UploadFileListener;
 import com.dayu.pipirrapp.utils.CleanDataUtils;
@@ -27,8 +29,6 @@
 import com.dayu.pipirrapp.utils.MyJsonParser;
 import com.dayu.pipirrapp.utils.MyLog;
 import com.dayu.pipirrapp.utils.NetUtils;
-import com.google.gson.Gson;
-import com.google.gson.internal.LinkedTreeMap;
 
 import java.io.File;
 import java.util.HashMap;
@@ -63,9 +63,10 @@
     //鏂囦欢涓婁紶澶辫触閲嶅娆℃暟
     int uplodFilerepeatSize = 3;
 
+
     ApiService apiService;
     // 绠$悊璁㈤槄浜嬩欢
-    private CompositeDisposable compositeDisposable = new CompositeDisposable();
+    private final CompositeDisposable compositeDisposable = new CompositeDisposable();
 
     /**
      * 鍒濆鍖栭�氫俊妗嗘灦
@@ -148,9 +149,9 @@
                             }
                             BaseResponse<T> response = new BaseResponse<>();
                             response.setCode(tem.getCode());
-                            if (!TextUtils.isEmpty(tem.getMsg())){
+                            if (!TextUtils.isEmpty(tem.getMsg())) {
                                 response.setMsg(tem.getMsg());
-                            }else {
+                            } else {
                                 response.setMsg("");
                             }
 
@@ -293,68 +294,105 @@
 //    }
 
     /**
-     * 涓婁紶鏂囦欢
+     * 涓婁紶鍥剧墖鏂囦欢
      *
      * @param context
      * @param uplodData
      * @param listener
      */
     public void uploadFile(final Context context, final UplodFileState uplodData, final UploadFileListener listener, final AddPictureAdapter adapter) {
-        MyLog.d("progressRequestBody>>>" + "path:" + uplodData.getFilePath() );
-        File file = new File(uplodData.getFilePath());
-        RequestBody requestBody = RequestBody.create(MediaType.parse("multipart/form-data"), file);
-        ProgressRequestBody progressRequestBody = new ProgressRequestBody(requestBody, (bytesWritten, contentLength, done) -> {
-//            MyLog.d("progressRequestBody>>>" + "bytesWritten:" + bytesWritten + ">>>contentLength: " + contentLength );
-            // 鏇存柊杩涘害鏉℃垨杩涜鍏朵粬鎿嶄綔
-            int progress = (int) (100 * bytesWritten / contentLength);
-            // 渚嬪锛氭洿鏂� ProgressBar 鎴栨樉绀鸿繘搴�
-            runOnUiThread(() -> {
-                uplodData.setProgress(progress);
-                // 杩涘害鏉℃洿鏂颁唬鐮�
-                if (adapter != null && uplodData.getAdapterPosition() != -1) {
-                    adapter.updateProgress(uplodData);
-                }
-                MyLog.d("progressRequestBody>>>" + "adapterPosition:" + uplodData.getAdapterPosition() + ">>>涓婁紶杩涘害: " + progress + "%");
-            });
 
-        });
-        MultipartBody.Part body = MultipartBody.Part.createFormData("file", file.getName(), progressRequestBody);
-        RequestBody description = RequestBody.create(MediaType.parse("text/plain"), "file description");
-        Call<BaseResponse> uploadFile = apiService.uploadFile(body, description);
-        uplodData.setThisCall(uploadFile);
-        uploadFile.enqueue(new Callback<BaseResponse>() {
-            @Override
-            public void onResponse(Call<BaseResponse> call, Response<BaseResponse> response) {
-                if (response.body() != null) {
-                    if (response.body().isSuccess()) {
-                        uplodData.setState(1);
-                        uplodData.setPostId(((LinkedTreeMap) response.body().getContent()).get("id").toString());
-                        uplodData.setWebPath(((LinkedTreeMap) response.body().getContent()).get("webPath").toString());
-                        listener.onBack(uplodData);
-                    } else {
-                        if (uplodData.getNumber() <= uplodFilerepeatSize) {
-                            uplodData.setNumber(uplodData.getNumber() + 1);
-                            uplodData.setState(2);
-                            uploadFile(context, uplodData, listener, adapter);
-                        } else {
+        if (!TextUtils.isEmpty(uplodData.getFilePath())) {
+            MyLog.d("progressRequestBody_uploadFile>>>" + "path:" + uplodData.getFilePath() + ">>>uploadType:" + uplodData.getUploadType());
+            uplodData.setState(STATE_UPDING);
+            File file = new File(uplodData.getFilePath());
+            RequestBody requestBody = RequestBody.create(MediaType.parse("multipart/form-data"), file);
+            ProgressRequestBody progressRequestBody = new ProgressRequestBody(requestBody, (bytesWritten, contentLength, done) -> {
+//            MyLog.d("progressRequestBody>>>" + "bytesWritten:" + bytesWritten + ">>>contentLength: " + contentLength );
+                // 鏇存柊杩涘害鏉℃垨杩涜鍏朵粬鎿嶄綔
+                int progress = (int) (100 * bytesWritten / contentLength);
+                // 渚嬪锛氭洿鏂� ProgressBar 鎴栨樉绀鸿繘搴�
+                runOnUiThread(() -> {
+                    if (progress <5) {
+                        uplodData.setProgress(0);
+                    }
+                    // 杩涘害鏉℃洿鏂颁唬鐮�
+                    if (adapter != null && uplodData.getAdapterPosition() != -1) {
+                        //浼樺寲涓嶉绻佹洿鏂拌繘搴�
+                        if (progress - uplodData.getProgress() > 5 || progress == 100) {
+                            uplodData.setProgress(progress);
+                            adapter.updateProgress(uplodData);
+
+                        }
+
+                    }
+                    MyLog.d("progressRequestBodyHolder>>>path" + "adapterPosition:" + uplodData.getAdapterPosition() + ">>>涓婁紶杩涘害: " + progress + "%");
+                });
+
+            });
+            MultipartBody.Part body = MultipartBody.Part.createFormData("file", file.getName(), progressRequestBody);
+            RequestBody description = RequestBody.create(MediaType.parse("text/plain"), "file description");
+            Call<BaseResponse<UploadFileResult>> uploadFile = null;
+            switch (uplodData.getUploadType()) {
+                case UplodFileState.IMG_TYPE:
+                    uploadFile = apiService.uploadImgFile(body, description);
+                    break;
+                case UplodFileState.VIDEO_TYPE:
+                    uploadFile = apiService.uploadVideoFile(body, description);
+                    break;
+                default:
+                    uploadFile = apiService.uploadImgFile(body, description);
+                    break;
+            }
+
+            uplodData.setThisCall(uploadFile);
+            uploadFile.enqueue(new Callback<BaseResponse<UploadFileResult>>() {
+                @Override
+                public void onResponse(Call<BaseResponse<UploadFileResult>> call, Response<BaseResponse<UploadFileResult>> response) {
+                    if (response.body() != null) {
+                        if (response.body().isSuccess()) {
+                            UploadFileResult uploadFileResult=response.body().getContent();
+                            uplodData.setState(STATE_DONE);
+                            uplodData.setPostId(uploadFileResult.getId());
+                            uplodData.setUoloadFilePath(uploadFileResult.getFilePath());
+                            uplodData.setHash(uploadFileResult.getHash());
+                            uplodData.setWebPathZip(uploadFileResult.getWebPathZip());
                             listener.onBack(uplodData);
+                        } else {
+                            MyLog.d("progressRequestBody>>>" + response.body().getMsg());
+                            if (uplodData.getNumber() <= uplodFilerepeatSize) {
+                                uplodData.setNumber(uplodData.getNumber() + 1);
+                                uplodData.setState(STATE_ERROR);
+                                uploadFile(context, uplodData, listener, adapter);
+                            } else {
+                                uplodData.setState(STATE_ERROR);
+                                uplodData.setNumber(0);
+                                listener.onBack(uplodData);
+                            }
                         }
                     }
                 }
-            }
 
-            @Override
-            public void onFailure(Call<BaseResponse> call, Throwable t) {
-                if (uplodData.getNumber() <= uplodFilerepeatSize) {
-                    uplodData.setNumber(uplodData.getNumber() + 1);
-                    uplodData.setState(2);
-                    uploadFile(context, uplodData, listener, adapter);
-                } else {
-                    listener.onBack(uplodData);
+                @Override
+                public void onFailure(Call<BaseResponse<UploadFileResult>> call, Throwable t) {
+                    MyLog.d("progressRequestBody>>>" + "onFailure:" + t.getMessage());
+                    if (!t.getMessage().equals("Canceled")) {
+                        uplodData.setState(STATE_ERROR);
+                        if (uplodData.getNumber() <= uplodFilerepeatSize) {
+                            uplodData.setNumber(uplodData.getNumber() + 1);
+                            uploadFile(context, uplodData, listener, adapter);
+                        } else {
+                            uplodData.setNumber(0);
+                            listener.onBack(uplodData);
+                        }
+                    }
+
                 }
-            }
-        });
-
+            });
+        } else {
+            uplodData.setState(STATE_ERROR);
+            listener.onBack(uplodData);
+        }
     }
 
 

--
Gitblit v1.8.0