From f8656588595af6cb716341b5daacba26e350a872 Mon Sep 17 00:00:00 2001 From: wjc <1243177876@qq.com> Date: 星期二, 27 六月 2023 17:42:10 +0800 Subject: [PATCH] 2023年06月27日17:42:08 --- 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