diff --git a/GenerateAlarmConst/App.config b/GenerateAlarmConst/App.config new file mode 100644 index 0000000..193aecc --- /dev/null +++ b/GenerateAlarmConst/App.config @@ -0,0 +1,6 @@ + + + + + + \ No newline at end of file diff --git a/GenerateAlarmConst/Form1.Designer.cs b/GenerateAlarmConst/Form1.Designer.cs new file mode 100644 index 0000000..0cce92b --- /dev/null +++ b/GenerateAlarmConst/Form1.Designer.cs @@ -0,0 +1,47 @@ +namespace GenerateAlarmConst +{ + partial class Form1 + { + /// + /// 必需的设计器变量。 + /// + private System.ComponentModel.IContainer components = null; + + /// + /// 清理所有正在使用的资源。 + /// + /// 如果应释放托管资源,为 true;否则为 false。 + protected override void Dispose(bool disposing) + { + if (disposing && (components != null)) + { + components.Dispose(); + } + base.Dispose(disposing); + } + + #region Windows 窗体设计器生成的代码 + + /// + /// 设计器支持所需的方法 - 不要修改 + /// 使用代码编辑器修改此方法的内容。 + /// + private void InitializeComponent() + { + this.SuspendLayout(); + // + // Form1 + // + this.AutoScaleDimensions = new System.Drawing.SizeF(6F, 12F); + this.AutoScaleMode = System.Windows.Forms.AutoScaleMode.Font; + this.ClientSize = new System.Drawing.Size(1148, 739); + this.Name = "Form1"; + this.Text = "Form1"; + this.ResumeLayout(false); + + } + + #endregion + } +} + diff --git a/GenerateAlarmConst/Form1.cs b/GenerateAlarmConst/Form1.cs new file mode 100644 index 0000000..0f4d49f --- /dev/null +++ b/GenerateAlarmConst/Form1.cs @@ -0,0 +1,20 @@ +using System; +using System.Collections.Generic; +using System.ComponentModel; +using System.Data; +using System.Drawing; +using System.Linq; +using System.Text; +using System.Threading.Tasks; +using System.Windows.Forms; + +namespace GenerateAlarmConst +{ + public partial class Form1 : Form + { + public Form1() + { + InitializeComponent(); + } + } +} diff --git a/GenerateAlarmConst/Form1.resx b/GenerateAlarmConst/Form1.resx new file mode 100644 index 0000000..1af7de1 --- /dev/null +++ b/GenerateAlarmConst/Form1.resx @@ -0,0 +1,120 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + text/microsoft-resx + + + 2.0 + + + System.Resources.ResXResourceReader, System.Windows.Forms, Version=4.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089 + + + System.Resources.ResXResourceWriter, System.Windows.Forms, Version=4.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089 + + \ No newline at end of file diff --git a/GenerateAlarmConst/GenerateAlarmConst.csproj b/GenerateAlarmConst/GenerateAlarmConst.csproj new file mode 100644 index 0000000..234b210 --- /dev/null +++ b/GenerateAlarmConst/GenerateAlarmConst.csproj @@ -0,0 +1,83 @@ + + + + + Debug + AnyCPU + {6FC7AA8C-FF1E-4F40-9644-23C4AF215880} + WinExe + GenerateAlarmConst + GenerateAlarmConst + v4.8 + 512 + true + true + + + AnyCPU + true + full + false + bin\Debug\ + DEBUG;TRACE + prompt + 4 + + + AnyCPU + pdbonly + true + bin\Release\ + TRACE + prompt + 4 + + + + + + + + + + + + + + + + + Form + + + Form1.cs + + + + + Form1.cs + + + ResXFileCodeGenerator + Resources.Designer.cs + Designer + + + True + Resources.resx + + + SettingsSingleFileGenerator + Settings.Designer.cs + + + True + Settings.settings + True + + + + + + + \ No newline at end of file diff --git a/GenerateAlarmConst/Program.cs b/GenerateAlarmConst/Program.cs new file mode 100644 index 0000000..be482b1 --- /dev/null +++ b/GenerateAlarmConst/Program.cs @@ -0,0 +1,22 @@ +using System; +using System.Collections.Generic; +using System.Linq; +using System.Threading.Tasks; +using System.Windows.Forms; + +namespace GenerateAlarmConst +{ + internal static class Program + { + /// + /// 应用程序的主入口点。 + /// + [STAThread] + static void Main() + { + Application.EnableVisualStyles(); + Application.SetCompatibleTextRenderingDefault(false); + Application.Run(new Form1()); + } + } +} diff --git a/GenerateAlarmConst/Properties/AssemblyInfo.cs b/GenerateAlarmConst/Properties/AssemblyInfo.cs new file mode 100644 index 0000000..c83c084 --- /dev/null +++ b/GenerateAlarmConst/Properties/AssemblyInfo.cs @@ -0,0 +1,36 @@ +using System.Reflection; +using System.Runtime.CompilerServices; +using System.Runtime.InteropServices; + +// 有关程序集的一般信息由以下 +// 控制。更改这些特性值可修改 +// 与程序集关联的信息。 +[assembly: AssemblyTitle("GenerateAlarmConst")] +[assembly: AssemblyDescription("")] +[assembly: AssemblyConfiguration("")] +[assembly: AssemblyCompany("")] +[assembly: AssemblyProduct("GenerateAlarmConst")] +[assembly: AssemblyCopyright("Copyright © 2025")] +[assembly: AssemblyTrademark("")] +[assembly: AssemblyCulture("")] + +// 将 ComVisible 设置为 false 会使此程序集中的类型 +//对 COM 组件不可见。如果需要从 COM 访问此程序集中的类型 +//请将此类型的 ComVisible 特性设置为 true。 +[assembly: ComVisible(false)] + +// 如果此项目向 COM 公开,则下列 GUID 用于类型库的 ID +[assembly: Guid("6fc7aa8c-ff1e-4f40-9644-23c4af215880")] + +// 程序集的版本信息由下列四个值组成: +// +// 主版本 +// 次版本 +// 生成号 +// 修订号 +// +//可以指定所有这些值,也可以使用“生成号”和“修订号”的默认值 +//通过使用 "*",如下所示: +// [assembly: AssemblyVersion("1.0.*")] +[assembly: AssemblyVersion("1.0.0.0")] +[assembly: AssemblyFileVersion("1.0.0.0")] diff --git a/GenerateAlarmConst/Properties/Resources.Designer.cs b/GenerateAlarmConst/Properties/Resources.Designer.cs new file mode 100644 index 0000000..c55b28d --- /dev/null +++ b/GenerateAlarmConst/Properties/Resources.Designer.cs @@ -0,0 +1,71 @@ +//------------------------------------------------------------------------------ +// +// 此代码由工具生成。 +// 运行时版本: 4.0.30319.42000 +// +// 对此文件的更改可能导致不正确的行为,如果 +// 重新生成代码,则所做更改将丢失。 +// +//------------------------------------------------------------------------------ + +namespace GenerateAlarmConst.Properties +{ + + + /// + /// 强类型资源类,用于查找本地化字符串等。 + /// + // 此类是由 StronglyTypedResourceBuilder + // 类通过类似于 ResGen 或 Visual Studio 的工具自动生成的。 + // 若要添加或移除成员,请编辑 .ResX 文件,然后重新运行 ResGen + // (以 /str 作为命令选项),或重新生成 VS 项目。 + [global::System.CodeDom.Compiler.GeneratedCodeAttribute("System.Resources.Tools.StronglyTypedResourceBuilder", "4.0.0.0")] + [global::System.Diagnostics.DebuggerNonUserCodeAttribute()] + [global::System.Runtime.CompilerServices.CompilerGeneratedAttribute()] + internal class Resources + { + + private static global::System.Resources.ResourceManager resourceMan; + + private static global::System.Globalization.CultureInfo resourceCulture; + + [global::System.Diagnostics.CodeAnalysis.SuppressMessageAttribute("Microsoft.Performance", "CA1811:AvoidUncalledPrivateCode")] + internal Resources() + { + } + + /// + /// 返回此类使用的缓存 ResourceManager 实例。 + /// + [global::System.ComponentModel.EditorBrowsableAttribute(global::System.ComponentModel.EditorBrowsableState.Advanced)] + internal static global::System.Resources.ResourceManager ResourceManager + { + get + { + if ((resourceMan == null)) + { + global::System.Resources.ResourceManager temp = new global::System.Resources.ResourceManager("GenerateAlarmConst.Properties.Resources", typeof(Resources).Assembly); + resourceMan = temp; + } + return resourceMan; + } + } + + /// + /// 重写当前线程的 CurrentUICulture 属性,对 + /// 使用此强类型资源类的所有资源查找执行重写。 + /// + [global::System.ComponentModel.EditorBrowsableAttribute(global::System.ComponentModel.EditorBrowsableState.Advanced)] + internal static global::System.Globalization.CultureInfo Culture + { + get + { + return resourceCulture; + } + set + { + resourceCulture = value; + } + } + } +} diff --git a/GenerateAlarmConst/Properties/Resources.resx b/GenerateAlarmConst/Properties/Resources.resx new file mode 100644 index 0000000..af7dbeb --- /dev/null +++ b/GenerateAlarmConst/Properties/Resources.resx @@ -0,0 +1,117 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + text/microsoft-resx + + + 2.0 + + + System.Resources.ResXResourceReader, System.Windows.Forms, Version=2.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089 + + + System.Resources.ResXResourceWriter, System.Windows.Forms, Version=2.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089 + + \ No newline at end of file diff --git a/GenerateAlarmConst/Properties/Settings.Designer.cs b/GenerateAlarmConst/Properties/Settings.Designer.cs new file mode 100644 index 0000000..831abcc --- /dev/null +++ b/GenerateAlarmConst/Properties/Settings.Designer.cs @@ -0,0 +1,30 @@ +//------------------------------------------------------------------------------ +// +// This code was generated by a tool. +// Runtime Version:4.0.30319.42000 +// +// Changes to this file may cause incorrect behavior and will be lost if +// the code is regenerated. +// +//------------------------------------------------------------------------------ + +namespace GenerateAlarmConst.Properties +{ + + + [global::System.Runtime.CompilerServices.CompilerGeneratedAttribute()] + [global::System.CodeDom.Compiler.GeneratedCodeAttribute("Microsoft.VisualStudio.Editors.SettingsDesigner.SettingsSingleFileGenerator", "11.0.0.0")] + internal sealed partial class Settings : global::System.Configuration.ApplicationSettingsBase + { + + private static Settings defaultInstance = ((Settings)(global::System.Configuration.ApplicationSettingsBase.Synchronized(new Settings()))); + + public static Settings Default + { + get + { + return defaultInstance; + } + } + } +} diff --git a/GenerateAlarmConst/Properties/Settings.settings b/GenerateAlarmConst/Properties/Settings.settings new file mode 100644 index 0000000..3964565 --- /dev/null +++ b/GenerateAlarmConst/Properties/Settings.settings @@ -0,0 +1,7 @@ + + + + + + + diff --git a/Rs.DeweyTester.sln b/Rs.DeweyTester.sln index c28acdd..b75d496 100644 --- a/Rs.DeweyTester.sln +++ b/Rs.DeweyTester.sln @@ -7,6 +7,8 @@ Project("{FAE04EC0-301F-11D3-BF4B-00C04F79EFBC}") = "Rs.DeweyTester", "Rs.DeweyT EndProject Project("{FAE04EC0-301F-11D3-BF4B-00C04F79EFBC}") = "Gugao.FunTest", "Gugao.FunTest\Gugao.FunTest.csproj", "{E8D7862F-FEA8-4923-987E-7BAF217DB5B9}" EndProject +Project("{FAE04EC0-301F-11D3-BF4B-00C04F79EFBC}") = "GenerateAlarmConst", "GenerateAlarmConst\GenerateAlarmConst.csproj", "{6FC7AA8C-FF1E-4F40-9644-23C4AF215880}" +EndProject Global GlobalSection(SolutionConfigurationPlatforms) = preSolution Debug|Any CPU = Debug|Any CPU @@ -21,6 +23,10 @@ Global {E8D7862F-FEA8-4923-987E-7BAF217DB5B9}.Debug|Any CPU.Build.0 = Debug|Any CPU {E8D7862F-FEA8-4923-987E-7BAF217DB5B9}.Release|Any CPU.ActiveCfg = Release|Any CPU {E8D7862F-FEA8-4923-987E-7BAF217DB5B9}.Release|Any CPU.Build.0 = Release|Any CPU + {6FC7AA8C-FF1E-4F40-9644-23C4AF215880}.Debug|Any CPU.ActiveCfg = Debug|Any CPU + {6FC7AA8C-FF1E-4F40-9644-23C4AF215880}.Debug|Any CPU.Build.0 = Debug|Any CPU + {6FC7AA8C-FF1E-4F40-9644-23C4AF215880}.Release|Any CPU.ActiveCfg = Release|Any CPU + {6FC7AA8C-FF1E-4F40-9644-23C4AF215880}.Release|Any CPU.Build.0 = Release|Any CPU EndGlobalSection GlobalSection(SolutionProperties) = preSolution HideSolutionNode = FALSE diff --git a/Rs.DeweyTester/Commom/DevLog.cs b/Rs.DeweyTester/Commom/DevLog.cs index bb8457b..8bf199a 100644 --- a/Rs.DeweyTester/Commom/DevLog.cs +++ b/Rs.DeweyTester/Commom/DevLog.cs @@ -1,5 +1,7 @@ using NPOI.OpenXmlFormats.Dml.Chart; +using NPOI.SS.Formula.Functions; using Rs.Framework; +using Rs.MotionPlat.Entitys; using System; using System.Collections.Generic; using System.IO; @@ -7,6 +9,7 @@ using System.Linq; using System.Text; using System.Threading.Tasks; using System.Windows.Forms; +using static System.Windows.Forms.VisualStyles.VisualStyleElement.ListView; namespace Rs.MotionPlat.Commom { @@ -37,7 +40,7 @@ namespace Rs.MotionPlat.Commom catch (Exception ex) { - LogHelper.Error($"Summary:{ex.Message + ex.StackTrace}"); + LogHelper.Error($"EventTracker:{ex.Message + ex.StackTrace}"); } } @@ -66,26 +69,51 @@ namespace Rs.MotionPlat.Commom } catch (Exception ex) { - LogHelper.Error($"Summary:{ex.Message + ex.StackTrace}"); + LogHelper.Error($"Breakdown:{ex.Message + ex.StackTrace}"); } } } - public static void UnitTracker() + public static void UnitTracker(TestFixture fixture) { lock (lockobj) { - string filename = ""; - string csvTitle = "SiteID,ProjectID,MachineID,Date,Time,LotName,LoginMode,Serial Number,Socker ID,Test Result,Trial,Socket Usage"; - if (!File.Exists(filename)) + try { - File.AppendAllText(filename, csvTitle); + int usage = 0; + string RetryMode = "T1"; + if (fixture.Product.TestNum > 0) + { + RetryMode = $"R{fixture.Product.TestNum}"; + } + string filename = $"{fileDir}\\{DateTime.Now.ToString("yyyyMMdd")}\\UnitTracker_{DateTime.Now.ToString("yyyyMMdd")}.csv"; + for (int i = 1; i <= 6; i++) + { + TestFixture tf = TestFixtureManager.Instance.GetTestFixture(i); + if (tf.Enable) + { + usage |= 1 << (i - 1); + } + } + string trial = string.Join("", Convert.ToString(usage, 2).Reverse()); + string csvTitle = "SiteID,ProjectID,MachineID,Date,Time,LotName,LoginMode,Serial Number,Socker ID,Test Result,Trial,Socket Usage"; + if (!Directory.Exists(Path.GetDirectoryName(filename))) + { + Directory.CreateDirectory(Path.GetDirectoryName(filename)); + } + if (!File.Exists(filename)) + { + File.AppendAllText(filename, csvTitle); + } + string content = $"{GlobalVar.SiteID},{GlobalVar.ProjectID},{GlobalVar.MachineID},{DateTime.Now.ToString("HH:mm:ss")},{DateTime.Now.ToString("HH:mm:ss")},{GlobalVar.LotName},OP,{fixture.Product.SN},{fixture.Index},{fixture.Result},{RetryMode},{trial}\r\n"; + File.AppendAllText(filename, content); } - else + catch (Exception ex) { - + LogHelper.Error($"UnitTracker:{ex.Message + ex.StackTrace}"); } + } } diff --git a/Rs.DeweyTester/Entitys/TestFixtureManager.cs b/Rs.DeweyTester/Entitys/TestFixtureManager.cs index 6f7f1b4..38cb4f6 100644 --- a/Rs.DeweyTester/Entitys/TestFixtureManager.cs +++ b/Rs.DeweyTester/Entitys/TestFixtureManager.cs @@ -642,6 +642,7 @@ namespace Rs.MotionPlat.Entitys TotalCount++; Yield = (double)((double)PassCount / TotalCount); AddTestRecordToProduct(); + DevLog.UnitTracker(this); //this.Product.AddResult(this.Index, Result, items[6]); } Status = ETestFixtureStatus.IDLE; diff --git a/Rs.DeweyTester/Flow/HomeFlow.cs b/Rs.DeweyTester/Flow/HomeFlow.cs index cf26d37..c5d7d49 100644 --- a/Rs.DeweyTester/Flow/HomeFlow.cs +++ b/Rs.DeweyTester/Flow/HomeFlow.cs @@ -210,7 +210,7 @@ namespace Rs.MotionPlat.Flow } else if(stopwatch.ElapsedMilliseconds>5000) { - Msgbox.ShowDialog(AlarmCollection.Get(AlarmConstID.料仓抽屉锁动位异常报警), EButtonType.Retry); + Msgbox.ShowDialog(AlarmCollection.Get(AlarmConstID.料仓抽屉锁动位异常报警).Transform(i), EButtonType.Retry); stopwatch.Restart(); } } diff --git a/Rs.DeweyTester/Flow/NormalFlow/StockFlowBase.cs b/Rs.DeweyTester/Flow/NormalFlow/StockFlowBase.cs index 8fe627d..7f68860 100644 --- a/Rs.DeweyTester/Flow/NormalFlow/StockFlowBase.cs +++ b/Rs.DeweyTester/Flow/NormalFlow/StockFlowBase.cs @@ -154,7 +154,7 @@ namespace Rs.MotionPlat.Flow.NormalFlow } else if (stopwatch.ElapsedMilliseconds > 5000) { - Msg.ShowError(AlarmCollection.Get(AlarmConstID.抽屉锁原位异常报警).Transform("1").CN); + Msg.ShowError(AlarmCollection.Get(AlarmConstID.抽屉锁原位异常报警).Transform(StockIndex).CN); outStockStep = EOutStockFlowStep.打开抽屉锁; } break; @@ -171,7 +171,7 @@ namespace Rs.MotionPlat.Flow.NormalFlow } else if (stopwatch.ElapsedMilliseconds > 5000) { - Msg.ShowError(AlarmCollection.Get(AlarmConstID.抽屉拉伸气缸动位异常).CN); + Msg.ShowError(AlarmCollection.Get(AlarmConstID.抽屉拉伸气缸动位异常).Transform(StockIndex).CN); outStockStep = EOutStockFlowStep.出仓; } break; @@ -233,7 +233,7 @@ namespace Rs.MotionPlat.Flow.NormalFlow } else if (stopwatch.ElapsedMilliseconds > 10000) { - AlarmEntity alarmEntity = AlarmCollection.Get(AlarmConstID.抽屉拉伸气缸原位异常); + AlarmEntity alarmEntity = AlarmCollection.Get(AlarmConstID.抽屉拉伸气缸原位异常).Transform(StockIndex); Msgbox.ShowDialog(alarmEntity, EButtonType.Recheck); inStockStep = EInStockFlowStep.进仓; } @@ -260,7 +260,7 @@ namespace Rs.MotionPlat.Flow.NormalFlow } else if (stopwatch.ElapsedMilliseconds > 5000) { - Msg.ShowError(AlarmCollection.Get(AlarmConstID.抽屉锁动位异常报警).CN); + Msg.ShowError(AlarmCollection.Get(AlarmConstID.抽屉锁动位异常报警).Transform(StockIndex).CN); inStockStep = EInStockFlowStep.关闭开抽屉锁; } break; diff --git a/Rs.DeweyTester/Program.cs b/Rs.DeweyTester/Program.cs index 0cd39ee..22168f5 100644 --- a/Rs.DeweyTester/Program.cs +++ b/Rs.DeweyTester/Program.cs @@ -29,6 +29,20 @@ namespace Rs.MotionPlat [STAThread] static void Main() { + + int usage = 0; + + for (int i = 1; i <= 6; i++) + { + if (i==2 || i==3 ||i==5 || i==6) + { + usage |= 1 << (i - 1); + } + } + + string ss = string.Join ("", Convert.ToString(usage, 2).Reverse()); + + Application.EnableVisualStyles(); Application.SetCompatibleTextRenderingDefault(false); //Application.Run(new FormIO2()); diff --git a/Rs.DeweyTester/Properties/AssemblyInfo.cs b/Rs.DeweyTester/Properties/AssemblyInfo.cs index 29e92b6..902b954 100644 --- a/Rs.DeweyTester/Properties/AssemblyInfo.cs +++ b/Rs.DeweyTester/Properties/AssemblyInfo.cs @@ -31,6 +31,6 @@ using System.Runtime.InteropServices; // //可以指定所有这些值,也可以使用“生成号”和“修订号”的默认值 //通过使用 "*",如下所示: - [assembly: AssemblyVersion("1.20.25.03")] + [assembly: AssemblyVersion("1.20.25.04")] //[assembly: AssemblyVersion("1.0.0.0")] //[assembly: AssemblyFileVersion("1.0.0.0")]