From 823f534dff0da0b34f68e32cdfe2651d1bb81db3 Mon Sep 17 00:00:00 2001
From: wjc <1243177876@qq.com>
Date: 星期三, 12 七月 2023 17:16:40 +0800
Subject: [PATCH] 2023年07月12日17:16:39

---
 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