From 4f7f99c6ea914bcd38de78bd8371be566026b905 Mon Sep 17 00:00:00 2001 From: zuoxiao <470321431@qq.com> Date: 星期三, 26 二月 2025 15:54:14 +0800 Subject: [PATCH] -为按钮和列表项添加波纹效果,以获得更好的视觉反馈 -改进MapFragment中的底部布局动画 -在MapFragment中添加设备状态和RTU地址显示 -更新BaseListResult以支持泛型类型 -为设备数据添加IntakeListResult和IntakeResult -通过数据库支持增强标记位置更新功能 -添加电话拨号意图以分隔标记详细信息 -通过过期检查改进磁贴缓存 -添加问题报告的确认对话框 -更新登录活动以限制用户名长度 -为波纹效果和UI元素添加新颜色 -重构XML布局以使用新的波纹图 -改进MapFragment中的错误处理和用户反馈 --- 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