From c91d4503a63013be3242120ae0ad9cd1b0b8127e Mon Sep 17 00:00:00 2001
From: zuoxiao <470321431@qq.com>
Date: 星期四, 12 十二月 2024 17:18:54 +0800
Subject: [PATCH] 优化定位服务相关代码
---
app/src/main/java/com/dayu/pipirrapp/net/ApiManager.java | 108 ++++++++++++++++++++++++++++++++++++++++++------------
1 files changed, 84 insertions(+), 24 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 dc7a736..d6ba8f9 100644
--- a/app/src/main/java/com/dayu/pipirrapp/net/ApiManager.java
+++ b/app/src/main/java/com/dayu/pipirrapp/net/ApiManager.java
@@ -1,9 +1,14 @@
package com.dayu.pipirrapp.net;
+import static com.luck.picture.lib.thread.PictureThreadUtils.runOnUiThread;
+
+import android.annotation.SuppressLint;
import android.content.Context;
+import android.content.Intent;
import android.util.Log;
import com.dayu.pipirrapp.MyApplication;
+import com.dayu.pipirrapp.activity.LoginActivity;
import com.dayu.pipirrapp.bean.net.CodeResult;
import com.dayu.pipirrapp.bean.net.UplodFileState;
import com.dayu.pipirrapp.bean.net.WeatherResponse;
@@ -11,11 +16,18 @@
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.ProgressListener;
+import com.dayu.pipirrapp.net.upload.ProgressRequestBody;
import com.dayu.pipirrapp.net.upload.UploadFileListener;
+import com.dayu.pipirrapp.utils.CleanDataUtils;
import com.dayu.pipirrapp.utils.MapJpgUtils;
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;
import java.util.List;
import java.util.Map;
@@ -124,6 +136,12 @@
public BaseResponse<T> apply(Object o) {
if (o instanceof BaseResponse) {
BaseResponse tem = (BaseResponse) o;
+ if (tem.getCode().equals("0000")) {
+ //褰揷ode涓�0000鏄烦杞埌鐧诲綍鐣岄潰
+ tem.setMsg("鐧诲綍澶辨晥璇烽噸鏂扮櫥褰�");
+ redirectToLogin();
+ return tem;
+ }
BaseResponse<T> response = new BaseResponse<>();
response.setCode(tem.getCode());
response.setMsg(tem.getMsg());
@@ -222,6 +240,7 @@
*
* @param urlPath
*/
+ @SuppressLint("CheckResult")
public void donwLoadTile(Context context, String urlPath) {
if (NetUtils.isNetworkAvailable(context)) {
Observable<ResponseBody> observable;
@@ -261,34 +280,46 @@
* 涓婁紶鏂囦欢
*
* @param context
- * @param file
+ * @param uplodData
* @param listener
*/
- public void uploadFile(final Context context, final UplodFileState file, final UploadFileListener listener) {
+ public void uploadFile(final Context context, final UplodFileState uplodData, final UploadFileListener listener) {
- // 鍒涘缓 RequestBody锛岀敤浜庡皝瑁呮瀯寤篟equestBody
- RequestBody requestFile =
- RequestBody.create(MediaType.parse("multipart/form-data"), file.getFile());
- // MultipartBody.Part 鍜屽悗绔害瀹氬ソKey锛岃繖閲岀殑partName鏄敤image
- MultipartBody.Part body = MultipartBody.Part.createFormData("file", file.getFile().getName(), requestFile);
- // 娣诲姞鎻忚堪
- String descriptionString = "hello, 杩欐槸鏂囦欢鎻忚堪";
- RequestBody description = RequestBody.create(MediaType.parse("multipart/form-data"), descriptionString);
- apiService.uploadFile(description, body).enqueue(new Callback<BaseResponse>() {
+ File file = new File(uplodData.getFilePath());
+ RequestBody requestBody = RequestBody.create(MediaType.parse("multipart/form-data"), file);
+ ProgressRequestBody progressRequestBody = new ProgressRequestBody(requestBody, new ProgressListener() {
+ @Override
+ public void onProgress(long bytesWritten, long contentLength, boolean done) {
+ // 鏇存柊杩涘害鏉℃垨杩涜鍏朵粬鎿嶄綔
+ int progress = (int) (100 * bytesWritten / contentLength);
+ // 渚嬪锛氭洿鏂� ProgressBar 鎴栨樉绀鸿繘搴�
+ runOnUiThread(() -> {
+ // 杩涘害鏉℃洿鏂颁唬鐮�
+ // progressBar.setProgress(progress);
+ MyLog.d("progressRequestBody>>>" + "涓婁紶杩涘害: " + 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()) {
- file.setState(1);
- file.setUrl(response.body().getMsg());
- listener.onBack(file);
+ uplodData.setState(1);
+ uplodData.setId(((LinkedTreeMap) response.body().getContent()).get("id").toString());
+ uplodData.setWebPath(((LinkedTreeMap) response.body().getContent()).get("webPath").toString());
+ listener.onBack(uplodData);
} else {
- if (file.getNumber() <= uplodFilerepeatSize) {
- file.setNumber(file.getNumber() + 1);
- file.setState(2);
- uploadFile(context, file, listener);
+ if (uplodData.getNumber() <= uplodFilerepeatSize) {
+ uplodData.setNumber(uplodData.getNumber() + 1);
+ uplodData.setState(2);
+ uploadFile(context, uplodData, listener);
} else {
- listener.onBack(file);
+ listener.onBack(uplodData);
}
}
}
@@ -296,16 +327,45 @@
@Override
public void onFailure(Call<BaseResponse> call, Throwable t) {
- if (file.getNumber() <= uplodFilerepeatSize) {
- file.setNumber(file.getNumber() + 1);
- file.setState(2);
- uploadFile(context, file, listener);
+ if (uplodData.getNumber() <= uplodFilerepeatSize) {
+ uplodData.setNumber(uplodData.getNumber() + 1);
+ uplodData.setState(2);
+ uploadFile(context, uplodData, listener);
} else {
- listener.onBack(file);
+ listener.onBack(uplodData);
}
}
});
+
}
+ /**
+ * 鍒ゆ柇褰撳墠code鏄惁鏄湭鐧诲綍鐘舵��
+ *
+ * @param responseBody the response body in JSON format
+ * @return true if login is required, false otherwise
+ */
+ private boolean isLoginRequired(String responseBody) {
+ try {
+ Gson gson = new Gson();
+ Map<String, Object> responseMap = gson.fromJson(responseBody, Map.class);
+ String code = (String) responseMap.get("code");
+ return "0000".equals(code); // Check if the code is not 0000
+ } catch (Exception e) {
+ e.printStackTrace();
+ }
+ return false;
+ }
+ /**
+ * 褰揷ode涓衡��0000鈥濇椂璺宠浆鍒扮櫥褰曠晫闈�
+ */
+ private void redirectToLogin() {
+
+ Context context = MyApplication.myApplication.getApplicationContext();
+ CleanDataUtils.cleanUserData(context);
+ Intent intent = new Intent(context, LoginActivity.class); // Assuming LoginActivity is your login screen
+ intent.addFlags(Intent.FLAG_ACTIVITY_NEW_TASK | Intent.FLAG_ACTIVITY_CLEAR_TASK); // Clear task stack
+ context.startActivity(intent);
+ }
}
\ No newline at end of file
--
Gitblit v1.8.0