mirror of
				https://github.com/MewoLab/AquaDX.git
				synced 2025-10-26 12:32:40 +00:00 
			
		
		
		
	[+] ShowErrorLog (#74)
* [+] ShowErrorLog * [O] Fixed spelling errors in method names
This commit is contained in:
		
							parent
							
								
									c074de5876
								
							
						
					
					
						commit
						98213cff67
					
				| @ -100,6 +100,10 @@ JudgeAdjustB=0.0 | ||||
| TouchDelay=0 | ||||
| # Show detail of selected song in music selection screen | ||||
| SelectionDetail=true | ||||
| # Show Network error detail in the game | ||||
| ShowNetErrorDetail=true | ||||
| # Show error log in the game | ||||
| ShowErrorLog=false | ||||
| # Display framerate | ||||
| FrameRateDisplay=false | ||||
| # Practice mode, activated by pressing Test in the game | ||||
|  | ||||
| @ -120,6 +120,8 @@ TouchDelay=0 | ||||
| SelectionDetail=true | ||||
| # 出现灰网时显示原因 | ||||
| ShowNetErrorDetail=true | ||||
| # 在游戏中显示错误日志窗口而不是关闭游戏进程 | ||||
| ShowErrorLog=false | ||||
| # 显示帧率 | ||||
| FrameRateDisplay=false | ||||
| # 练习模式,在游戏中按 Test 打开 | ||||
|  | ||||
| @ -74,6 +74,7 @@ namespace AquaMai | ||||
|             public bool PractiseMode { get; set; } | ||||
|             public bool SelectionDetail { get; set; } | ||||
|             public bool ShowNetErrorDetail { get; set; } | ||||
|             public bool ShowErrorLog { get; set; } | ||||
|             public bool FrameRateDisplay { get; set; } | ||||
|             public int TouchPanelBaudRate { get; set; } | ||||
|         } | ||||
|  | ||||
							
								
								
									
										96
									
								
								AquaMai/Utils/ShowErrorLog.cs
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										96
									
								
								AquaMai/Utils/ShowErrorLog.cs
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,96 @@ | ||||
| using System; | ||||
| using System.Collections; | ||||
| using System.IO; | ||||
| using System.Text.RegularExpressions; | ||||
| using System.Threading; | ||||
| using AquaMai.Helpers; | ||||
| using HarmonyLib; | ||||
| using Main; | ||||
| using MelonLoader; | ||||
| using UnityEngine; | ||||
| 
 | ||||
| namespace AquaMai.Utils; | ||||
| 
 | ||||
| public class ShowErrorLog | ||||
| { | ||||
|     private static Ui _errorUi; | ||||
| 
 | ||||
|     [HarmonyPostfix] | ||||
|     [HarmonyPatch(typeof(GameMain), "ExceptionHandler")] | ||||
|     private static void ExceptionHandler(GameMain __instance, Exception e) | ||||
|     { | ||||
|         if (_errorUi == null) | ||||
|         { | ||||
|             _errorUi = new GameObject("ErrorUI").AddComponent<Ui>(); | ||||
|             _errorUi.gameObject.SetActive(true); | ||||
|         } | ||||
|         string logFile = $"{MAI2System.Path.ErrorLogPath}{DateTime.Now:yyyyMMddHHmmss}.log"; | ||||
|         MelonLogger.Msg("Error Log:"); | ||||
|         if (File.Exists(logFile)) | ||||
|         { | ||||
|             MelonLogger.Error(File.ReadAllText(logFile)); | ||||
|             _errorUi.SetErrorLog(File.ReadAllText(logFile)); | ||||
|         } | ||||
|         else | ||||
|         { | ||||
|             MelonLogger.Error(e); | ||||
|             _errorUi.SetErrorLog(e.ToString()); | ||||
|         } | ||||
| 
 | ||||
|         Application.quitting += ApplicationOnQuitting; | ||||
|         _errorUi.StartCoroutine(_errorUi.Show()); | ||||
|     } | ||||
| 
 | ||||
|     private static void ApplicationOnQuitting() | ||||
|     { | ||||
|         Thread.Sleep(Timeout.Infinite); | ||||
|     } | ||||
| 
 | ||||
|     private class Ui : MonoBehaviour | ||||
|     { | ||||
|         private string _errorLog = ""; | ||||
|          | ||||
|         public void SetErrorLog(string text) | ||||
|         { | ||||
|             _errorLog = "Error Log:\n" + text; | ||||
|         } | ||||
| 
 | ||||
|         public void OnGUI() | ||||
|         { | ||||
|             var labelStyle = new GUIStyle(GUI.skin.label) | ||||
|             { | ||||
|                 fontSize = GuiSizes.FontSize, | ||||
|                 alignment = TextAnchor.MiddleLeft, | ||||
|                 normal = new GUIStyleState(){textColor = Color.black} | ||||
|             }; | ||||
| 
 | ||||
|             var boxStyle = new GUIStyle(GUI.skin.box) | ||||
|             { | ||||
|                 normal = new GUIStyleState() { background = Texture2D.whiteTexture } | ||||
|             }; | ||||
|              | ||||
|             int logLineCount = Regex.Matches(_errorLog, "\n").Count + 1; | ||||
|             float offset = GuiSizes.PlayerCenter * 0.12f; | ||||
|             var x = GuiSizes.PlayerCenter / 2f + offset / 2f; | ||||
|             var y = Screen.height / 1.8f; | ||||
|             var width = GuiSizes.PlayerCenter - offset; | ||||
|             var height = GuiSizes.LabelHeight * logLineCount + GuiSizes.Margin * 2; | ||||
| 
 | ||||
|             GUI.Box(new Rect(x, y, width, height), "", boxStyle); | ||||
|             GUI.Label(new Rect(x, y, width, height), _errorLog, labelStyle); | ||||
|             if (!AquaMai.AppConfig.UX.SinglePlayer) | ||||
|             { | ||||
|                 GUI.Box(new Rect(x + GuiSizes.PlayerWidth, y, width, height), "", boxStyle); | ||||
|                 GUI.Label(new Rect(x + GuiSizes.PlayerWidth, y, width, height), _errorLog, labelStyle); | ||||
|             } | ||||
|         } | ||||
|          | ||||
|         public IEnumerator Show() | ||||
|         { | ||||
|             while (true) | ||||
|             { | ||||
|                 yield return null; // 让 Unity 处理一帧 | ||||
|             } | ||||
|         } | ||||
|     } | ||||
| } | ||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user
	 WYH2004
						WYH2004