From a3798b01c03911efcd7f7b28f78cebc35871c528 Mon Sep 17 00:00:00 2001
From: mac <user@users-MacBook-Pro.local>
Date: 星期二, 06 八月 2024 18:37:07 +0800
Subject: [PATCH] 2024年08月06日18:37:05
---
app/src/main/java/com/hdl/photovoltaic/other/HdlLogLogic.java | 127 ++++++++++++++++++++++++++++++++++++++----
1 files changed, 114 insertions(+), 13 deletions(-)
diff --git a/app/src/main/java/com/hdl/photovoltaic/other/HdlLogLogic.java b/app/src/main/java/com/hdl/photovoltaic/other/HdlLogLogic.java
index 8c9892c..ff3cde6 100644
--- a/app/src/main/java/com/hdl/photovoltaic/other/HdlLogLogic.java
+++ b/app/src/main/java/com/hdl/photovoltaic/other/HdlLogLogic.java
@@ -1,30 +1,131 @@
package com.hdl.photovoltaic.other;
-import android.util.Log;
+
+import android.util.LruCache;
+
+import com.google.gson.Gson;
+import com.hdl.photovoltaic.config.UserConfigManage;
+import com.hdl.photovoltaic.utils.TimeUtils;
/**
* 鏃ュ織閫昏緫
*/
public class HdlLogLogic {
- private static volatile HdlLogLogic sHdlLogLogic;
+ //鏄惁闇�瑕佹墦鍗板埌Logcat涓�(false涓嶉渶瑕佹墦鍗�)
+ public static boolean isPrintLogcat = true;
- public static synchronized HdlLogLogic getInstance() {
- if (sHdlLogLogic == null) {
- synchronized (HdlLogLogic.class) {
- if (sHdlLogLogic == null) {
- sHdlLogLogic = new HdlLogLogic();
- }
+ //榛樿鎵撳嵃鏍囬
+ private static String logTitle = "鑷畾涔夎緭鍑烘墦鍗颁俊鎭�";
+
+ private static Gson gson = new Gson();
+
+ /**
+ * java鎵撳嵃
+ *
+ * @param customizeContentFormat 鑷畾涔夊唴瀹规牸寮�
+ */
+ public static void print(String customizeContentFormat) {
+ printBase(customizeContentFormat, "0", false);
+ }
+
+ /**
+ * java鎵撳嵃
+ *
+ * @param customizeContentFormat 鑷畾涔夊唴瀹规牸寮�
+ * @param isAddToMemory 鏄惁鍔犲叆鍐呭瓨(鏈湴鏃ュ織鐢ㄥ埌)
+ */
+ public static void print(String customizeContentFormat, boolean isAddToMemory) {
+ printBase(customizeContentFormat, "0", isAddToMemory);
+ }
+
+ /**
+ * java鎵撳嵃
+ *
+ * @param msg 鑷畾涔夊唴瀹规牸寮�
+ * @param code 鐘舵�佺爜
+ * @param isAddToMemory 鏄惁鍔犲叆鍐呭瓨(鏈湴鏃ュ織鐢ㄥ埌)
+ */
+ public static void print(String msg, int code, boolean isAddToMemory) {
+ printBase(msg, code + "", isAddToMemory);
+ }
+
+
+ /**
+ * java鎵撳嵃鍜屽瓨鍌ㄦ棩蹇�
+ *
+ * @param msg 淇℃伅鎻忚堪
+ * @param code 鐘舵��
+ * @param isAddToMemory 鏄惁鍔犲叆鍐呭瓨(鏈湴鏃ュ織鐢ㄥ埌)
+ */
+ private static void printBase(String msg, String code, boolean isAddToMemory) {
+ try {
+ CustomLogObject customLogObject = new CustomLogObject();
+ customLogObject.setMsgOrData(msg);
+ customLogObject.setCode(code);
+ String json = logTitle + (UserConfigManage.getInstance().isBAccount() ? "(B绔�)==" : "(C绔�)==") + gson.toJson(customLogObject);
+ if (isPrintLogcat) {
+ System.out.println(json);
}
+ if (isAddToMemory) {
+ writeLog(json);
+ }
+ } catch (Exception ignored) {
}
- return sHdlLogLogic;
- }
-
- public static void print(String tag, String mgs) {
- Log.d(tag, mgs);
}
+ /**
+ * 鍐欏叆鏃ュ織鍐呭鍒版湰鍦�
+ *
+ * @param strLog 鍐欏叆鍐呭
+ */
+ public static void writeLog(String strLog) {
+ synchronized (HdlLogLogic.class) {
+ strLog = TimeUtils.getTimeFromTimestamp(System.currentTimeMillis()) + "s%" + " " + strLog;//鍔犳墦鍗版椂闂�(s%鍗犱綅绗︼紝璁剧疆鏄剧ず鏃堕棿涓嶅悓瀛椾綋棰滆壊)
+ HdlFileLogic.getInstance().appendFile(HdlFileLogic.getInstance().getLogFileNamePath(), strLog);
+ }
+ }
+
+ /**
+ * 璇诲彇鏃ュ織鍐呭
+ *
+ * @return 鏃ュ織鍐呭
+ */
+ public static String readLog() {
+ return HdlFileLogic.getInstance().readFile(HdlFileLogic.getInstance().getLogFileNamePath());
+ }
+
+
+ /**
+ * 鑷畾涔夋棩蹇楃被
+ */
+ static class CustomLogObject {
+
+ //淇℃伅鎻忚堪
+ private String msgOrData;
+
+ //鐘舵�佺爜
+ private String code;
+
+ public String getMsgOrData() {
+ return msgOrData == null ? "" : msgOrData;
+ }
+
+ public void setMsgOrData(String msgOrData) {
+ this.msgOrData = msgOrData;
+ }
+
+ public String getCode() {
+ return code == null ? "0" : code;
+ }
+
+ public void setCode(String code) {
+ this.code = code;
+ }
+
+
+ }
}
--
Gitblit v1.8.0