|  |  |  | using DyeingComputer.UserClass; | 
					
						
							|  |  |  | using System; | 
					
						
							|  |  |  | using System.Collections.Generic; | 
					
						
							|  |  |  | using System.ComponentModel; | 
					
						
							|  |  |  | using System.Configuration; | 
					
						
							|  |  |  | using System.Data; | 
					
						
							|  |  |  | using System.IO; | 
					
						
							|  |  |  | using System.Linq; | 
					
						
							|  |  |  | using System.Runtime.InteropServices; | 
					
						
							|  |  |  | using System.Threading; | 
					
						
							|  |  |  | using System.Threading.Tasks; | 
					
						
							|  |  |  | using System.Windows; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | namespace DyeingComputer | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |     /// <summary>
 | 
					
						
							|  |  |  |     /// App.xaml 的交互逻辑
 | 
					
						
							|  |  |  |     /// </summary>
 | 
					
						
							|  |  |  |     public partial class App : Application | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         private UserClass.IniFile.IniFiles Configini = new UserClass.IniFile.IniFiles(Convert.ToString(System.AppDomain.CurrentDomain.BaseDirectory) + "DyeingComputer.ini"); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         public App() | 
					
						
							|  |  |  |         { | 
					
						
							|  |  |  |             this.Startup += new StartupEventHandler(App_Startup); | 
					
						
							|  |  |  |             this.DispatcherUnhandledException += new System.Windows.Threading.DispatcherUnhandledExceptionEventHandler(App_DispatcherUnhandledException); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |             DyeingComputer.Properties.Resources.Culture = new System.Globalization.CultureInfo(Configini.IniReadvalue("SYS", "Language"));//设定语言
 | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         System.Threading.Mutex mutex; | 
					
						
							|  |  |  |         void App_Startup(object sender, StartupEventArgs e)  | 
					
						
							|  |  |  |         {        | 
					
						
							|  |  |  |             bool ret; | 
					
						
							|  |  |  |             mutex = new System.Threading.Mutex(true, "ElectronicNeedleTherapySystem", out ret);//程序只允许启动一次
 | 
					
						
							|  |  |  |             if (!ret) | 
					
						
							|  |  |  |             { | 
					
						
							|  |  |  |                 LogGing.LogGingDATA("800_The program has been launched"); | 
					
						
							|  |  |  |                 MessageBox.Show("The program has been launched"); | 
					
						
							|  |  |  |                 Environment.Exit(0); | 
					
						
							|  |  |  |             } | 
					
						
							|  |  |  |             LogGing.LogGingDATA("800_Start"); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |             SystemSleepTool.PreventSleep(); | 
					
						
							|  |  |  |              | 
					
						
							|  |  |  |             //return Container.Resolve<MainWindow>();
 | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         protected override void OnStartup(StartupEventArgs e)  //跟踪报错信息
 | 
					
						
							|  |  |  |         { | 
					
						
							|  |  |  |             base.OnStartup(e); | 
					
						
							|  |  |  |             //UI线程的异常捕捉
 | 
					
						
							|  |  |  |             this.DispatcherUnhandledException += App_DispatcherUnhandledException; | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         private void App_DispatcherUnhandledException(object sender, System.Windows.Threading.DispatcherUnhandledExceptionEventArgs e) | 
					
						
							|  |  |  |         { | 
					
						
							|  |  |  |             e.Handled = true; | 
					
						
							|  |  |  |             if (e.Exception.InnerException == null) | 
					
						
							|  |  |  |             { | 
					
						
							|  |  |  |                 MessageBox.Show("发生了一个无法处理的错误!请联系SUNLIGHT处理!" | 
					
						
							|  |  |  |                     + "(1)错误" + Environment.NewLine | 
					
						
							|  |  |  |                     + "(2)错误源:" + e.Exception.Source + Environment.NewLine | 
					
						
							|  |  |  |                                 //  + (3)详细信息:" + e.Exception.Message + Environment.NewLine                             
 | 
					
						
							|  |  |  |                                 //  + "(4)报错区域:" + e.Exception.StackTrace
 | 
					
						
							|  |  |  |                                 ); | 
					
						
							|  |  |  |             } | 
					
						
							|  |  |  |             else | 
					
						
							|  |  |  |             { | 
					
						
							|  |  |  |                 MessageBox.Show("发生了一个无法处理的错误!请联系SUNLIGHT处理!" | 
					
						
							|  |  |  |                     + "(1)错误" + Environment.NewLine | 
					
						
							|  |  |  |                     //      + "(2)错误源:" + e.Exception.InnerException.Source + Environment.NewLine  
 | 
					
						
							|  |  |  |                     + "(3)错误信息:" + e.Exception.Message + Environment.NewLine | 
					
						
							|  |  |  |                 //      + "(4)详细信息:" + e.Exception.InnerException.Message + Environment.NewLine
 | 
					
						
							|  |  |  |                 //      + "(5)报错区域:" + e.Exception.InnerException.StackTrace
 | 
					
						
							|  |  |  |                                 ); | 
					
						
							|  |  |  |             } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |             string Log_time = DateTime.Now.ToString("yyyy-MM-dd"); | 
					
						
							|  |  |  |             string logpath = System.Environment.CurrentDirectory + "\\ERR";//日志文件目录
 | 
					
						
							|  |  |  |             //string logPathtxt = "" + System.Environment.CurrentDirectory + "\\Log\\"+ Log_time + "Log.txt";//日志文件
 | 
					
						
							|  |  |  |             // System.IO.DirectoryInfo log = new System.IO.DirectoryInfo();//生成日志文件目录
 | 
					
						
							|  |  |  |             string log_path = logpath + "\\ERR" + Log_time + ".txt"; | 
					
						
							|  |  |  |             string Log_timehms = DateTime.Now.ToString("yyyy-MM-dd HH:mm:ss"); | 
					
						
							|  |  |  |             if (Directory.Exists(logpath))//检查日志路径
 | 
					
						
							|  |  |  |             { | 
					
						
							|  |  |  |                 if (!File.Exists(log_path))//检查文件并写入
 | 
					
						
							|  |  |  |                 { | 
					
						
							|  |  |  |                     FileStream fs = new FileStream(log_path, FileMode.CreateNew, FileAccess.Write);//创建文件 
 | 
					
						
							|  |  |  |                     StreamWriter wr = new StreamWriter(fs);//创建文件
 | 
					
						
							|  |  |  |                     wr.Close(); | 
					
						
							|  |  |  |                     FileStream fil = new FileStream(log_path, FileMode.Append, FileAccess.Write);//创建写入文件 
 | 
					
						
							|  |  |  |                     StreamWriter wfil = new StreamWriter(fil);//创建文件
 | 
					
						
							|  |  |  |                     wfil.WriteLine("[" + Log_timehms + "];[Error] ||" + Environment.NewLine.ToString()); | 
					
						
							|  |  |  |                     wfil.WriteLine("[" + Log_timehms + "];[Error source] ||" + e.Exception.Source.ToString() + Environment.NewLine.ToString()); | 
					
						
							|  |  |  |                     wfil.WriteLine("[" + Log_timehms + "];[Error message] ||" + e.Exception.Message.ToString() + Environment.NewLine.ToString()); | 
					
						
							|  |  |  |                     wfil.WriteLine("[" + Log_timehms + "];[Error area] ||" + e.Exception.StackTrace.ToString()); | 
					
						
							|  |  |  |                     wfil.Close(); | 
					
						
							|  |  |  |                 } | 
					
						
							|  |  |  |                 else | 
					
						
							|  |  |  |                 { | 
					
						
							|  |  |  |                     FileStream fs = new FileStream(log_path, FileMode.Append, FileAccess.Write);//创建写入文件 
 | 
					
						
							|  |  |  |                     StreamWriter wr = new StreamWriter(fs);//创建文件
 | 
					
						
							|  |  |  |                     wr.WriteLine("[" + Log_timehms + "];[Error] ||" + Environment.NewLine.ToString()); | 
					
						
							|  |  |  |                     wr.WriteLine("[" + Log_timehms + "];[Error source] ||" + e.Exception.Source.ToString() + Environment.NewLine.ToString()); | 
					
						
							|  |  |  |                     wr.WriteLine("[" + Log_timehms + "];[Error message] ||" + e.Exception.Message.ToString() + Environment.NewLine.ToString()); | 
					
						
							|  |  |  |                     wr.WriteLine("[" + Log_timehms + "];[Error area] ||" + e.Exception.StackTrace.ToString()); | 
					
						
							|  |  |  |                     wr.Close(); | 
					
						
							|  |  |  |                 } | 
					
						
							|  |  |  |             } | 
					
						
							|  |  |  |             else | 
					
						
							|  |  |  |             { | 
					
						
							|  |  |  |                 DirectoryInfo directoryInfo = new DirectoryInfo(logpath); | 
					
						
							|  |  |  |                 directoryInfo.Create(); | 
					
						
							|  |  |  |             } | 
					
						
							|  |  |  |         }      | 
					
						
							|  |  |  |         /// <summary>
 | 
					
						
							|  |  |  |         /// 启动初始页面
 | 
					
						
							|  |  |  |         /// </summary>   
 | 
					
						
							|  |  |  |         private void Application_Startup(object sender, StartupEventArgs e)    | 
					
						
							|  |  |  |         {         | 
					
						
							|  |  |  |             Application.Current.StartupUri = new Uri("MainWindow.xaml", UriKind.Relative);//和MainWindwo同一目录          
 | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         public static class SystemSleepTool | 
					
						
							|  |  |  |         { | 
					
						
							|  |  |  |             //定义API函数
 | 
					
						
							|  |  |  |             [DllImport("kernel32.dll")] | 
					
						
							|  |  |  |             static extern uint SetThreadExecutionState(ExecutionFlag flags); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |             [Flags] | 
					
						
							|  |  |  |             enum ExecutionFlag : uint | 
					
						
							|  |  |  |             { | 
					
						
							|  |  |  |                 ES_SYSTEM_REQUIRED = 0x00000001, | 
					
						
							|  |  |  |                 ES_DISPLAY_REQUIRED = 0x00000002, | 
					
						
							|  |  |  |                 ES_CONTINUOUS = 0x80000000, | 
					
						
							|  |  |  |             } | 
					
						
							|  |  |  |             /// <summary>
 | 
					
						
							|  |  |  |             ///阻止系统休眠
 | 
					
						
							|  |  |  |             /// </summary>
 | 
					
						
							|  |  |  |             public static void PreventSleep() | 
					
						
							|  |  |  |             { | 
					
						
							|  |  |  |                 SetThreadExecutionState(ExecutionFlag.ES_SYSTEM_REQUIRED | ExecutionFlag.ES_DISPLAY_REQUIRED | ExecutionFlag.ES_CONTINUOUS); | 
					
						
							|  |  |  |             } | 
					
						
							|  |  |  |             /// <summary>
 | 
					
						
							|  |  |  |             ///恢复系统休眠
 | 
					
						
							|  |  |  |             /// </summary>
 | 
					
						
							|  |  |  |             public static void RestoreSleep() | 
					
						
							|  |  |  |             { | 
					
						
							|  |  |  |                 SetThreadExecutionState(ExecutionFlag.ES_CONTINUOUS); | 
					
						
							|  |  |  |             } | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | } |