From d185499d036e1edcc0362935664ad89b783111d0 Mon Sep 17 00:00:00 2001
From: hxb <hxb@hdlchina.com.cn>
Date: 星期四, 29 六月 2023 10:09:28 +0800
Subject: [PATCH] 可搜索网关
---
app/src/main/java/com/hdl/photovoltaic/other/HdlThreadLogic.java | 141 +++++++++++++++++++++++++++++------------------
1 files changed, 87 insertions(+), 54 deletions(-)
diff --git a/app/src/main/java/com/hdl/photovoltaic/other/HdlThreadLogic.java b/app/src/main/java/com/hdl/photovoltaic/other/HdlThreadLogic.java
index 40bb756..a50ae9f 100644
--- a/app/src/main/java/com/hdl/photovoltaic/other/HdlThreadLogic.java
+++ b/app/src/main/java/com/hdl/photovoltaic/other/HdlThreadLogic.java
@@ -1,10 +1,17 @@
package com.hdl.photovoltaic.other;
+import android.app.Dialog;
import android.content.Context;
import android.os.Handler;
import android.os.Looper;
+import android.util.Log;
+import android.widget.Toast;
+
+import androidx.appcompat.app.AlertDialog;
import com.hdl.photovoltaic.enums.ShowErrorMode;
+import com.hdl.photovoltaic.widget.ConfirmationDialog;
+import com.hdl.photovoltaic.widget.ConfirmationExceptionDialog;
/**
* 绾跨▼閫昏緫
@@ -12,29 +19,13 @@
public class HdlThreadLogic {
private static final Handler handler = new Handler(Looper.getMainLooper());
- /**
- * 鍒囨崲鍥炰富绾跨▼
- *
- * @param run 鍥炶皟
- */
- public static void runMainThread(Runnable run) {
- try {
- if (Looper.myLooper() == Looper.getMainLooper()) {
- run.run();
- } else {
- handler.post(run);
- }
- } catch (Exception e) {
- exception(e, ShowErrorMode.YES);
- }
- }
/**
- * 鍒囨崲鍥炰富绾跨▼
+ * 鍒囨崲鍥炰富绾跨▼鎵ц
*
* @param run 鍥炶皟
- * @param context 涓婁笅鏂�
- * @param showErrorMode 鏄惁鏄剧ず閿欒
+ * @param context 涓婁笅鏂�(涓嶉渶瑕佸脊妗嗗~null)
+ * @param showErrorMode 鏄惁鏄剧ず閿欒(涓嶉渶瑕佹樉绀洪敊璇~null)
*/
public static void runMainThread(Runnable run, Context context, ShowErrorMode showErrorMode) {
try {
@@ -44,36 +35,18 @@
handler.post(run);
}
} catch (Exception e) {
- exception(e, showErrorMode);
+
+ exception(e, showErrorMode, context);
}
}
- /**
- * 瀛愮嚎绋�
- *
- * @param run 鍥炶皟
- */
- public static void runThread(Runnable run) {
-
- new Thread(new Runnable() {
- @Override
- public void run() {
- try {
- run.run();
- } catch (Exception e) {
- exception(e, ShowErrorMode.NO);
- }
- }
- }).start();
-
- }
/**
- * 瀛愮嚎绋�
+ * 瀛愮嚎绋嬫墽琛�
*
* @param run 鍥炶皟
- * @param context 涓婁笅鏂�
- * @param showErrorMode 鏄惁鏄剧ず閿欒
+ * @param context 涓婁笅鏂�(涓嶉渶瑕佸脊妗嗗~null)
+ * @param showErrorMode 鏄惁鏄剧ず閿欒(涓嶉渶瑕佸~null)
*/
public static void runThread(Runnable run, Context context, ShowErrorMode showErrorMode) {
@@ -83,7 +56,7 @@
try {
run.run();
} catch (Exception e) {
- exception(e, showErrorMode);
+ exception(e, showErrorMode, context);
}
}
}).start();
@@ -91,7 +64,40 @@
}
- private static void exception(Exception e, ShowErrorMode showErrorMode) {
+ /**
+ * 鍏ㄥ眬寮瑰嚭妗�,绯荤粺榛樿Toast
+ */
+ public static void toast(final Context context, final String text) {
+ handler.post(new Runnable() {
+ @Override
+ public void run() {
+ Toast.makeText(context, text, Toast.LENGTH_SHORT).show();
+ }
+ });
+ }
+
+ /**
+ * 鍏ㄥ眬寮瑰嚭妗�,绯荤粺榛樿Toast
+ */
+ public static void toast(final Context context, final int resId) {
+ handler.post(new Runnable() {
+ @Override
+ public void run() {
+ Toast.makeText(context, resId, Toast.LENGTH_SHORT).show();
+ }
+ });
+ }
+
+
+ /**
+ * @param ex 寮傚父淇℃伅绫�
+ * @param context 涓婁笅鏂�(涓嶉渶瑕佸脊妗嗗~null)
+ * @param showErrorMode 鏄惁鏄剧ず閿欒(涓嶉渶瑕佸~null)
+ */
+ private static void exception(Exception ex, ShowErrorMode showErrorMode, Context context) {
+ if (showErrorMode == null || context == null || ex == null) {
+ return;
+ }
if (showErrorMode == ShowErrorMode.NO) {
return;
}
@@ -99,18 +105,45 @@
handler.post(new Runnable() {
@Override
public void run() {
-// Dialog alertDialog = new AlertDialog.Builder(HDLApp.getInstance().getApplicationContext()).
-// setTitle("鎶辨瓑绋嬪簭鍑虹幇閿欒浜�,鐐瑰嚮\"纭\"鑾峰彇鏇村璇︾粏淇℃伅.").
-// setMessage(e.getMessage()).
-// create();
-// alertDialog.show();
- //鎻愮ず
-// AlertDialog alertDialog=new AlertDialog(HDLApp.getInstance().getApplicationContext(), androidx.fragment.R.style.TextAppearance_Compat_Notification);
-// alertDialog.setTitle("鎶辨瓑绋嬪簭鍑虹幇閿欒浜�");
-// alertDialog.show();
- //Toast.makeText(HDLApp.getInstance().getApplicationContext(), "鎶辨瓑绋嬪簭鍑虹幇閿欒浜�", Toast.LENGTH_SHORT).show();
+
+ ConfirmationDialog confirmationDialog = new ConfirmationDialog(context);
+ confirmationDialog.setTitle("鎻愮ず");
+ confirmationDialog.setContent("寰堟姳姝�,绋嬪簭鍑虹幇閿欒浜�,鐐瑰嚮\"纭\"鑾峰彇鏇村璇︾粏閿欒淇℃伅.");
+ confirmationDialog.setConfirmation("纭");
+ confirmationDialog.setCancel("鍙栨秷");
+ confirmationDialog.show();
+ confirmationDialog.setNoOnclickListener(new ConfirmationDialog.onNoOnclickListener() {
+ @Override
+ public void Cancel() {
+ confirmationDialog.dismiss();
+ }
+ });
+ confirmationDialog.setYesOnclickListener(new ConfirmationDialog.onYesOnclickListener() {
+ @Override
+ public void Confirm() {
+ confirmationDialog.dismiss();
+ ConfirmationExceptionDialog confirmationExceptionDialog = new ConfirmationExceptionDialog(context);
+// String s = getStackTrace(ex);
+ String s = Log.getStackTraceString(ex);
+ confirmationExceptionDialog.setContent(s);
+ confirmationExceptionDialog.show();
+ }
+ });
}
});
}
+
+ /**
+ * @return 璋冪敤鏍�
+ */
+ private static String getStackTrace(Exception ex) {
+ StringBuilder sb = new StringBuilder("");
+ StackTraceElement[] trace = ex.getStackTrace();
+ for (StackTraceElement stackTraceElement : trace) {
+ sb.append(stackTraceElement).append("\n");
+ }
+ return sb.toString();
+ }
+
}
--
Gitblit v1.8.0