From e5a090685df3d5e96a37b141d9a1d002d36f16f2 Mon Sep 17 00:00:00 2001
From: zuoxiao <470321431@qq.com>
Date: 星期五, 14 二月 2025 16:53:43 +0800
Subject: [PATCH] 1.web地图添加管网显示。 2.安卓原生添加管网信息的获取。 3.安卓原生添加管网信息的本地持久化(SQLite数据库)。 4.实现图例用户的选择状态按钮的持久化。 5.实现自定义搜索按钮的实现。 6.实现搜索后弹出界面的相关功能开发。

---
 app/src/main/java/com/dayu/pipirrapp/net/ApiManager.java |   34 +++++++++++++++++++++++-----------
 1 files changed, 23 insertions(+), 11 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 7e5671c..e21da6e 100644
--- a/app/src/main/java/com/dayu/pipirrapp/net/ApiManager.java
+++ b/app/src/main/java/com/dayu/pipirrapp/net/ApiManager.java
@@ -17,6 +17,7 @@
 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;
@@ -28,7 +29,6 @@
 import com.dayu.pipirrapp.utils.MyJsonParser;
 import com.dayu.pipirrapp.utils.MyLog;
 import com.dayu.pipirrapp.utils.NetUtils;
-import com.google.gson.internal.LinkedTreeMap;
 
 import java.io.File;
 import java.util.HashMap;
@@ -62,6 +62,7 @@
     static ApiManager apiManager;
     //鏂囦欢涓婁紶澶辫触閲嶅娆℃暟
     int uplodFilerepeatSize = 3;
+
 
     ApiService apiService;
     // 绠$悊璁㈤槄浜嬩欢
@@ -302,7 +303,7 @@
     public void uploadFile(final Context context, final UplodFileState uplodData, final UploadFileListener listener, final AddPictureAdapter adapter) {
 
         if (!TextUtils.isEmpty(uplodData.getFilePath())) {
-            MyLog.d("progressRequestBody>>>" + "path:" + uplodData.getFilePath()+">>>uploadType:"+uplodData.getUploadType());
+            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);
@@ -312,18 +313,26 @@
                 int progress = (int) (100 * bytesWritten / contentLength);
                 // 渚嬪锛氭洿鏂� ProgressBar 鎴栨樉绀鸿繘搴�
                 runOnUiThread(() -> {
-                    uplodData.setProgress(progress);
+                    if (progress <5) {
+                        uplodData.setProgress(0);
+                    }
                     // 杩涘害鏉℃洿鏂颁唬鐮�
                     if (adapter != null && uplodData.getAdapterPosition() != -1) {
-                        adapter.updateProgress(uplodData);
+                        //浼樺寲涓嶉绻佹洿鏂拌繘搴�
+                        if (progress - uplodData.getProgress() > 5 || progress == 100) {
+                            uplodData.setProgress(progress);
+                            adapter.updateProgress(uplodData);
+
+                        }
+
                     }
-                    MyLog.d("progressRequestBody>>>" + "adapterPosition:" + uplodData.getAdapterPosition() + ">>>涓婁紶杩涘害: " + progress + "%");
+                    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> uploadFile = null;
+            Call<BaseResponse<UploadFileResult>> uploadFile = null;
             switch (uplodData.getUploadType()) {
                 case UplodFileState.IMG_TYPE:
                     uploadFile = apiService.uploadImgFile(body, description);
@@ -337,14 +346,17 @@
             }
 
             uplodData.setThisCall(uploadFile);
-            uploadFile.enqueue(new Callback<BaseResponse>() {
+            uploadFile.enqueue(new Callback<BaseResponse<UploadFileResult>>() {
                 @Override
-                public void onResponse(Call<BaseResponse> call, Response<BaseResponse> response) {
+                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(((LinkedTreeMap) response.body().getContent()).get("id").toString());
-                            uplodData.setWebPath(((LinkedTreeMap) response.body().getContent()).get("webPath").toString());
+                            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());
@@ -362,7 +374,7 @@
                 }
 
                 @Override
-                public void onFailure(Call<BaseResponse> call, Throwable t) {
+                public void onFailure(Call<BaseResponse<UploadFileResult>> call, Throwable t) {
                     MyLog.d("progressRequestBody>>>" + "onFailure:" + t.getMessage());
                     if (!t.getMessage().equals("Canceled")) {
                         uplodData.setState(STATE_ERROR);

--
Gitblit v1.8.0