using AntdUI; using AntdUI.Svg; using DH.Commons.Enums; using DH.Devices.Camera; using DH.Devices.Devices; using DH.Devices.Motion; using DH.Devices.PLC; using DH.Devices.Vision; using DHSoftware.Languages; using DHSoftware.Models; using DHSoftware.Utils; using DHSoftware.Views; using DVPCameraType; using HalconDotNet; using Microsoft.Win32; using OpenCvSharp; using System; using System.CodeDom; using System.Collections.Concurrent; using System.Collections.Generic; using System.Diagnostics; using System.Drawing; using System.Linq; using System.Runtime.InteropServices; using System.Text; using System.Threading; using System.Threading.Tasks; using System.Windows.Forms; using XKRS.UI.Device.Winform; using static AntdUI.Math3D; using Camera = DHSoftware.Models.Camera; namespace DHSoftware { public partial class MainWindow : AntdUI.Window { private UserControl currControl; private bool isUpdatingTabs = false;//用于阻止Tabs更新 private bool isLight = true; // 定义一个语言切换事件 public event EventHandler LanguageChanged; private System.Windows.Forms.Timer refreshTimer; private int testCounter = 1; Dictionary> _cameraRelatedDetectionDict = null; public MainWindow() { InitializeComponent(); refreshTimer = new System.Windows.Forms.Timer(); refreshTimer.Interval = 1000; // 1秒间隔 refreshTimer.Tick += RefreshTimer_Tick; //refreshTimer.Start(); //初始化数据 InitData(); //绑定事件 BindEventHandler(); UserConfigFrm userControlFrm = new UserConfigFrm(); userControlFrm.Window = this; userControlFrm.Dock = DockStyle.Fill; tabPage2.Controls.Add(userControlFrm); // List Cameras = new List //{ // new Camera // { // DeviceName = "Cam1", // Alias = "相机1", // ImagePath = @"D:\1.jpeg" // }, // new Camera // { // DeviceName = "Cam2", // Alias = "相机2", // ImagePath = @"D:\2.jpeg" // }, // new Camera // { // DeviceName = "Cam3", // Alias = "相机3", // ImagePath = @"D:\3.jpeg" // }, // new Camera // { // DeviceName = "Cam4", // Alias = "相机4", // ImagePath = @"D:\4.jpeg" // }, // new Camera // { // DeviceName = "Cam5", // Alias = "相机5", // ImagePath = @"D:\5.jpeg" // } //}; // if (Cameras.Count > 0) // { // tabImgDisplay.Controls.Clear(); // foreach (var cam in Cameras) // { // AntdUI.TabPage tabPage = new AntdUI.TabPage(); // tabPage.Name = $"tab{cam.DeviceName}"; // tabPage.Text = cam.Alias; // //ImgDisplayControl imgDisplayControl = new ImgDisplayControl(); // //imgDisplayControl.Name = $"img{cam.DeviceName}"; // //imgDisplayControl.Dock = DockStyle.Fill; // //tabPage.Controls.Add(imgDisplayControl); // PictureBox pictureBox = new PictureBox(); // pictureBox.Name = $"pic{cam.DeviceName}"; // pictureBox.Dock = DockStyle.Fill; // pictureBox.SizeMode = PictureBoxSizeMode.Zoom; // tabPage.Controls.Add(pictureBox); // tabImgDisplay.Pages.Add(tabPage); // } // } } private void RefreshTimer_Tick(object sender, EventArgs e) { //// 获取相机1的控件(通过控件名称查找) //var targetControl = FindControlRecursive(tabImgDisplay, "picCam1") as PictureBox; //if (targetControl != null) //{ // // 生成测试路径(示例路径) // string testPath = $@"D:\{testCounter}.png"; // 循环1-5的图片 // testCounter++; // // 加载并显示图片 // targetControl.Image = Image.FromFile(testPath); // if (testCounter == 5) // { // testCounter = 1; // } // targetControl.Parent.Invalidate(); //} } // 递归查找控件的方法 private Control FindControlRecursive(Control parent, string name) { if (parent.Name == name) return parent; foreach (Control child in parent.Controls) { var found = FindControlRecursive(child, name); if (found != null) return found; } return null; } // 触发事件 protected virtual void OnLanguageChanged(EventArgs e) { LanguageChanged?.Invoke(this, e); } private void InitData() { //根据系统亮暗初始化一次 isLight = ThemeHelper.IsLightMode(); button_color.Toggle = !isLight; ThemeHelper.SetColorMode(this, isLight); //初始化消息弹出位置 Config.ShowInWindow = true; } private void BindEventHandler() { buttonSZ.Click += ButtonSZ_Click; button_color.Click += Button_color_Click; //监听系统深浅色变化 SystemEvents.UserPreferenceChanged += SystemEvents_UserPreferenceChanged; } private void SystemEvents_UserPreferenceChanged(object sender, UserPreferenceChangedEventArgs e) { if (e.Category == UserPreferenceCategory.General) { isLight = ThemeHelper.IsLightMode(); button_color.Toggle = !isLight; ThemeHelper.SetColorMode(this, isLight); } } private void Button_color_Click(object sender, EventArgs e) { isLight = !isLight; //这里使用了Toggle属性切换图标 button_color.Toggle = !isLight; ThemeHelper.SetColorMode(this, isLight); } private void ButtonSZ_Click(object sender, EventArgs e) { } public List HKCameras { get; } = new List(); public List Cameras { get; } = new List(); public Dictionary Dectection { get; } = new Dictionary(); public XinJEPLCTcpNet PLC { get; } = new XinJEPLCTcpNet(); SLDMotion sLDMotion = new SLDMotion(); private void MainWindow_Load(object sender, EventArgs e) { } private void MainWindow_FormClosed(object sender, FormClosedEventArgs e) { foreach (var camera in Cameras) { camera.CameraDisConnect(); } foreach (var camera in HKCameras) { //var hk as HikVisionCamera; //camera.CameraDisConnect(); } PLC.PLCDisConnect(); } private void segmented1_SelectIndexChanged(object sender, EventArgs e) { // Get the index of the selected item int selectedIndex = segmented1.SelectIndex; // Handle each button based on its index switch (selectedIndex) { case 0: // "启动" (Start) HandleStartButton(); break; case 1: // "停止" (Stop) HandleStopButton(); break; case 2: // "复位" (Reset) HandleResetButton(); break; case 3: // "设置" (Settings) HandleSettingsButton(); break; case 4: // "登录" (Login) HandleLoginButton(); break; default: break; } } public bool CurrentMachine = false; public volatile int ProductNum_Total = 0; public volatile int ProductNum_OK = 0; private readonly object _cameraSummaryLock = new object(); public SimboVisionDriver? _visionEngine = null; List DetectionConfigs = new List(); List SimboStationMLEngineList = new List(); Dictionary HalconToolDict = new Dictionary(); public List RecongnitionLabelList { get; set; } = new List(); public DateTime startTime; private void HandleStartButton() { CurrentMachine = true; //_visionEngine.Start(); //[Category("深度学习检测配置")] //[DisplayName("检测标签定义集合")] //[Description("定义检测标签的集合,例如:Seg/Detection模式:断裂、油污、划伤...;Class模式:ok、ng、上面、下面、套环、正常...")] //[TypeConverter(typeof(CollectionCountConvert))] //[Editor(typeof(ComplexCollectionEditor), typeof(UITypeEditor))] RecongnitionLabel recongnition = new RecongnitionLabel { LabelName = "youwu", LabelDescription = "油污", LabelCategory = "A_NG" }; RecongnitionLabel recongnition2 = new RecongnitionLabel { LabelName = "youwu", LabelDescription = "油污", LabelCategory = "A_NG" }; RecongnitionLabel recongnition3 = new RecongnitionLabel { LabelName = "youwu", LabelDescription = "油污", LabelCategory = "A_NG" }; RecongnitionLabelList.Add(recongnition); RecongnitionLabelList.Add(recongnition2); RecongnitionLabelList.Add(recongnition3); var det1 = new DetectionConfig("相机1", MLModelType.ObjectDetection, @"D:\PROJECTS\X015\Vision\Cam1.onnx", false, "Cam1"); var det2 = new DetectionConfig("相机2", MLModelType.ObjectDetection, @"D:\PROJECTS\X015\Vision\Cam2.onnx", false, "Cam2"); var det3 = new DetectionConfig("相机3", MLModelType.ObjectDetection, @"D:\PROJECTS\X015\Vision\Cam3.onnx", false, "Cam3"); var det4 = new DetectionConfig("相机4", MLModelType.ObjectDetection, @"D:\PROJECTS\X015\Vision\Cam4.onnx", false, "Cam4"); var det5 = new DetectionConfig("相机5", MLModelType.ObjectDetection, @"D:\PROJECTS\X015\Vision\Cam5.onnx", false, "Cam5"); var det6 = new DetectionConfig("相机6", MLModelType.ObjectDetection, @"D:\PROJECTS\X015\Vision\Cam6.onnx", false, "Cam6"); var det7 = new DetectionConfig("相机7", MLModelType.ObjectDetection, @"D:\PROJECTS\X015\Vision\Cam7.onnx", false, "Cam7"); var det8 = new DetectionConfig("相机8", MLModelType.ObjectDetection, @"D:\PROJECTS\X015\Vision\Cam8.onnx", false, "Cam8"); List CameraCollects = new List(); CameraCollects.Add(new RelatedCamera("Cam1")); List CameraCollects2 = new List(); CameraCollects2.Add(new RelatedCamera("Cam2")); List CameraCollects3 = new List(); CameraCollects3.Add(new RelatedCamera("Cam3")); List CameraCollects4 = new List(); CameraCollects4.Add(new RelatedCamera("Cam4")); List CameraCollects5 = new List(); CameraCollects5.Add(new RelatedCamera("Cam5")); List CameraCollects6 = new List(); CameraCollects6.Add(new RelatedCamera("Cam6")); List CameraCollects7 = new List(); CameraCollects7.Add(new RelatedCamera("Cam7")); List CameraCollects8 = new List(); CameraCollects8.Add(new RelatedCamera("Cam8")); float Conf = 0.5f; det1.CameraCollects = CameraCollects; det1.ModelconfThreshold = Conf; det1.ModelWidth = 640; det1.ModelHeight = 640; det1.in_lable_path = "D:\\PROJECTS\\X015\\Vision\\Cam1.txt"; det1.IsEnabled = true; det1.ShowLocation.X = 1; det1.ShowLocation.Y = 1; det2.CameraCollects = CameraCollects2; det2.ModelconfThreshold = Conf; det2.ModelWidth = 640; det2.ModelHeight = 640; det2.in_lable_path = "D:\\PROJECTS\\X015\\Vision\\Cam2.txt"; det2.IsEnabled = true; det2.ShowLocation.X = 2; det2.ShowLocation.Y = 1; det3.CameraCollects = CameraCollects3; det3.ModelconfThreshold = Conf; det3.ModelWidth = 640; det3.ModelHeight = 640; det3.in_lable_path = "D:\\PROJECTS\\X015\\Vision\\Cam3.txt"; det3.IsEnabled = true; det3.ShowLocation.X = 3; det3.ShowLocation.Y = 1; det4.CameraCollects = CameraCollects4; det4.ModelconfThreshold = Conf; det4.ModelWidth = 640; det4.ModelHeight = 640; det4.in_lable_path = "D:\\PROJECTS\\X015\\Vision\\Cam4.txt"; det4.IsEnabled = true; det4.ShowLocation.X = 4; det4.ShowLocation.Y = 1; det5.CameraCollects = CameraCollects5; det5.ModelconfThreshold = Conf; det5.ModelWidth = 640; det5.ModelHeight = 640; det5.in_lable_path = "D:\\PROJECTS\\X015\\Vision\\Cam5.txt"; det5.IsEnabled = true; det5.ShowLocation.X = 1; det5.ShowLocation.Y = 2; det6.CameraCollects = CameraCollects6; det6.ModelconfThreshold = Conf; det6.ModelWidth = 640; det6.ModelHeight = 640; det6.in_lable_path = "D:\\PROJECTS\\X015\\Vision\\Cam6.txt"; det6.IsEnabled = true; det6.ShowLocation.X = 2; det6.ShowLocation.Y = 2; det7.CameraCollects = CameraCollects7; det7.ModelconfThreshold = Conf; det7.ModelWidth = 640; det7.ModelHeight = 640; det7.in_lable_path = "D:\\PROJECTS\\X015\\Vision\\Cam7.txt"; det7.IsEnabled = true; det7.ShowLocation.X = 3; det7.ShowLocation.Y = 2; det8.CameraCollects = CameraCollects8; det8.ModelconfThreshold = Conf; det8.ModelWidth = 640; det8.ModelHeight = 640; det8.in_lable_path = "D:\\PROJECTS\\X015\\Vision\\Cam8.txt"; det8.IsEnabled = true; det8.ShowLocation.X = 4; det8.ShowLocation.Y = 2; DetectionConfigs.Add(det1); DetectionConfigs.Add(det2); DetectionConfigs.Add(det3); DetectionConfigs.Add(det4); DetectionConfigs.Add(det5); DetectionConfigs.Add(det6); DetectionConfigs.Add(det7); DetectionConfigs.Add(det8); Cameras.Clear(); HKCameras.Clear(); Dectection.Clear(); _cameraRelatedDetectionDict = new(); #if false for (int i = 1; i <= 8; i++) { HikVisionCamera camera = new HikVisionCamera(); camera.CameraName = $"Cam{i}"; camera.CameraIP = $"192.168.{i}.1"; camera.ComputerIP = $"192.168.{i}.1"; camera.CameraConnect(); camera.OnHImageOutput += OnCameraHImageOutput; HKCameras.Add(camera); } #else //Do3ThinkCamera do3ThinkCamera1 = new Do3ThinkCamera(); //do3ThinkCamera1.dvpStreamFormat = dvpStreamFormat.S_RAW8; //do3ThinkCamera1.CameraName = "Cam1"; //do3ThinkCamera1.CameraConnect(); //do3ThinkCamera1.OnHImageOutput += OnCameraHImageOutput; // Cameras.Add(do3ThinkCamera1); for (int i = 1; i <= 8; i++) { Do3ThinkCamera cam = new Do3ThinkCamera(); if (i == 1) { cam.dvpStreamFormat = dvpStreamFormat.S_RAW8; } else { cam.dvpStreamFormat = dvpStreamFormat.S_RGB24; } cam.CameraName = $"Cam{i}"; Cameras.Add(cam); cam.CameraConnect(); cam.OnHImageOutput += OnCameraHImageOutput; } #endif DetectionConfigs.ForEach(detection => { detection.CameraCollects.ForEach(cam => { List Dets = new List { detection.Id }; if (!_cameraRelatedDetectionDict.ContainsKey(cam.CameraSourceId)) { _cameraRelatedDetectionDict.Add(cam.CameraSourceId, Dets); } else { _cameraRelatedDetectionDict[cam.CameraSourceId].Add(detection.Id); } } ); }); string inferenceDevice = "CPU"; _visionEngine = new SimboVisionDriver(); _visionEngine.DetectionConfigs = DetectionConfigs; _visionEngine.Init(); CtrlVisionRunBase ctrlVisionRun = new CtrlVisionRunBase(_visionEngine); tabImgDisplay.Controls.Add(ctrlVisionRun); //Add the code for the "启动" button click here ////初始化Halcon工具 //InitialHalconTools(); ////深度学习模型加载 //bool resultOK = InitialSimboMLEnginesAsync(); //if (resultOK) //{ // //初始化失败 // // return; //} //位置比较卡 sLDMotion.AxisSettings = new List(); AxisSetting axis1 = new AxisSetting(); axis1.AxisIndex = 0; axis1.AxisName = "转盘1"; axis1.IsAxisEnabled = true; //axis1.AlarmLogic = AxisDirection.Positive; sLDMotion.IODefinitionCollection = new List(); Motion(sLDMotion.IODefinitionCollection); sLDMotion.SnapshotSettings = new List(); int[] cameraPositions = { 24161, 33608, 39702, 45701 }; sLDMotion.SnapshotSettings.Add(new SnapshotSetting { IsEnabled = true, CameraIO = sLDMotion.IODefinitionCollection.FirstOrDefault(t => t.IOType == IOType.OUTPUT && t.IOIndex == 13), CameraPosition = 7613, StationNumber = 0 }); for (int i = 0; i < 4; i++) { sLDMotion.SnapshotSettings.Add(new SnapshotSetting { IsEnabled = true, CameraIO = sLDMotion.IODefinitionCollection.FirstOrDefault(t => t.IOType == IOType.OUTPUT && t.IOIndex == i), CameraPosition = cameraPositions[i], StationNumber = 0 }); } sLDMotion.BlowSettings = new List(); int[] BlowPositions = { 61353, 68566 }; sLDMotion.BlowSettings.Add(new BlowSetting { IsEnabled = true, BlowIO = sLDMotion.IODefinitionCollection.FirstOrDefault(t => t.IOType == IOType.OUTPUT && t.IOIndex == 5), BlowPosition = BlowPositions[0], StationNumber = 0 }); sLDMotion.BlowSettings.Add(new BlowSetting { IsEnabled = true, BlowIO = sLDMotion.IODefinitionCollection.FirstOrDefault(t => t.IOType == IOType.OUTPUT && t.IOIndex == 6), BlowPosition = BlowPositions[1], StationNumber = 0 }); //SnapshotSetting sna1 = new SnapshotSetting(); //sna1.IsEnabled = true; //sna1.CameraIO= sLDMotion.IODefinitionCollection.FirstOrDefault(t => t.IOType == IOType.OUTPUT && t.IOIndex == 0); //sna1.CameraPosition = 17000; //sna1.StationNumber = 0; // sLDMotion.SnapshotSettings.Add(sna1); sLDMotion.AxisSettings.Add(axis1); sLDMotion.Init(); sLDMotion.OnNewPieces -= MainMotion_NewPieces; sLDMotion.OnNewPieces += MainMotion_NewPieces; // sLDMotion.Start(); //PLC.IP = "192.168.6.6"; //PLC.Port = 502; //PLC.PLCConnect(); //PLC.OnNewPieces -= MainMotion_NewPieces; //PLC.OnNewPieces += MainMotion_NewPieces; ProductBaseCount = 8; for (int i = 0; i < ProductBaseCount * ProductListMulti; i++) { ConcurrentDictionary products = new ConcurrentDictionary(); _productLists.Add(products); } sLDMotion.AxisStop(); bool e = sLDMotion.CArdReset(); //转盘速度 sLDMotion.JOGRun(14000, 100000); startTime = DateTime.Now; } public void Motion(List iODefinitions) { for (int i = 0; i < 16; i++) { iODefinitions.Add(new IODefinition { IOType = IOType.INPUT, IOIndex = i, IODesc = $"入料传感器{i + 1}" }); } for (int i = 0; i < 16; i++) { iODefinitions.Add(new IODefinition { IOType = IOType.OUTPUT, IOIndex = i, IODesc = $"入料传感器{i + 1}" }); } } private uint PieceCount = 0; private List> _productLists = new List>(); private int ProductListMulti = 2; private int ProductBaseCount = 0; private int PieceNumberToIndex(uint pn) { // 物料编号,取余 集合数量 int ret = (int)(pn % (ProductBaseCount * ProductListMulti)); return ret; } DateTime _ctTime = DateTime.Now; public async void MainMotion_NewPieces(int axisIndex, uint pieceNumber) { //if (MachineState != MachineState.Running && MachineState != MachineState.Warning) //{ // return; //} PieceCount++; int index = PieceNumberToIndex(pieceNumber); // productDatas.Add(pData); //转盘2 的物料是不是重新覆盖之前的pDta if (axisIndex == 1) { ProductData pData = new ProductData("", pieceNumber, ProductBaseCount); _productLists[index][pieceNumber] = pData; } string logStr = $"时间:{DateTime.Now} 轴{axisIndex}新产品{pieceNumber}加入队列{index}----入料计数{PieceCount}\n"; Task.Run(() => { //this.BeginInvoke(new MethodInvoker(delegate () { richTextBox1.AppendText(logStr); })); }); DateTime dtNow = DateTime.Now; UpdateCT(null, (float)(dtNow - _ctTime).TotalSeconds); _ctTime = dtNow; } public async Task UpdateCT(object objData, float ctTime) { await Task.Run(() => { //OnUpdateCT?.Invoke(objData, ctTime); }); } /// /// 相机回调 /// /// /// /// private void OnCameraHImageOutput(DateTime dt, CameraBase camera, Mat imageSet) { //if (camera.CameraName.Equals("cam1", StringComparison.OrdinalIgnoreCase)) //{ // Console.WriteLine(); //} //if (camera.CameraName.Equals("cam2", StringComparison.OrdinalIgnoreCase)) //{ // Console.WriteLine(); //} // 获取该相机的拍照计数 uint productNumber = (uint)camera.SnapshotCount; Task.Run(async () => { using (Mat localImageSet = imageSet.Clone()) // 复制 Mat 避免并发问题 { // imageSet?.Dispose(); // 拍照计数与物件编号一致,查找对应的产品 ProductData product = null; //内外壁模组多个相机的处理方法 //计算队列的方法不变 int index = PieceNumberToIndex(productNumber); // 找到产品存放在哪个队列里 ConcurrentDictionary tmpDic = _productLists[index]; try { int retryTimes = 100; while (product == null && retryTimes > 0) { if (tmpDic.ContainsKey(productNumber)) { product = tmpDic[productNumber]; } else { // Thread.Sleep(20); await Task.Delay(20); } retryTimes--; } // 如果产品为空,则销毁图片,提示错误 if (null == product) { List pnList = tmpDic.Keys.ToList(); string pnStr = ""; if (pnList != null && pnList.Count > 0) { pnStr = string.Join(",", pnList); } //LogAsync(DateTime.Now, LogLevel.Error, $"{camera.Name} 未找到产品,编号:{productNumber},队列{index}数量:{tmpDic.Count},列表:{pnStr}"); localImageSet.Dispose(); this.BeginInvoke(new MethodInvoker(delegate () { int currentScrollPosition = richTextBox1.GetPositionFromCharIndex(richTextBox1.TextLength).Y; richTextBox1.AppendText(productNumber + "提前推出" + camera.CameraName); // 设置回原来的滚动位置 richTextBox1.SelectionStart = richTextBox1.TextLength; richTextBox1.ScrollToCaret(); })); //重新生成实例 销毁之前的实例 using (StreamWriter sw = new StreamWriter("D://123log.txt", true, Encoding.UTF8)) { sw.WriteLine(productNumber + "提前推出" + camera.CameraName); } return; } // LogAsync(DateTime.Now, LogLevel.Information, $"{camera.Name} 找到产品{productNumber},队列{index}数量:{tmpDic.Count}"); if (!_cameraRelatedDetectionDict.ContainsKey(camera.CameraName)) { localImageSet.Dispose(); this.BeginInvoke(new MethodInvoker(delegate () { int currentScrollPosition = richTextBox1.GetPositionFromCharIndex(richTextBox1.TextLength).Y; richTextBox1.AppendText(productNumber + "提前推出" + camera.CameraName); // 设置回原来的滚动位置 richTextBox1.SelectionStart = richTextBox1.TextLength; richTextBox1.ScrollToCaret(); })); //重新生成实例 销毁之前的实例 using (StreamWriter sw = new StreamWriter("D://123log.txt", true, Encoding.UTF8)) { sw.WriteLine(productNumber + "提前推出" + camera.CameraName); } // LogAsync(DateTime.Now, LogLevel.Warning, $"{camera.Name} 找到产品{productNumber},但是没有推理1"); return; } double totalTime = 0.0; List resultStates = new List(); List? detectionDict = _cameraRelatedDetectionDict[camera.CameraName]; for (int i = 0; i < detectionDict.Count; i++) { string detectionId = detectionDict[i]; // 1. 预处理 using (Mat inferenceImage = localImageSet.Clone()) // 仅在此处克隆,确保推理过程中 Mat 有独立副本 { DetectStationResult temp1=_visionEngine.RunInference(inferenceImage, detectionId); resultStates.Add(temp1.ResultState); product.ResultCollection.Add(temp1); } } product.InferenceOne(); // LogAsync(DateTime.Now, LogLevel.Information, $"{camera.Name} 推理完成,产品{productNumber}"); if (!product.InferenceFinished()) { return; } ProductNum_Total++; CalculateOEE(); this.BeginInvoke(new MethodInvoker(delegate () { int currentScrollPosition = richTextBox1.GetPositionFromCharIndex(richTextBox1.TextLength).Y; richTextBox1.AppendText($"统计结果成功,{productNumber} 吹气!\n"); // 设置回原来的滚动位置 richTextBox1.SelectionStart = richTextBox1.TextLength; richTextBox1.ScrollToCaret(); })); #region 6. 统计产品结果 product.ProductResult = product.ResultCollection.Any(u => u.ResultState != ResultState.OK) ? ResultState.B_NG : ResultState.OK; product.ProductLabelCategory = product.ProductResult.GetEnumDescription(); product.ProductLabel = product.ProductResult.GetEnumDescription(); #endregion #region 7.产品吹气 #endregion // 出列 ProductData temp = null; int tryTimes = 10; while (temp == null && tryTimes > 0) { if (tmpDic.TryRemove(productNumber, out temp)) { break; } tryTimes--; Thread.Sleep(5); } if (temp == null) { string logStr = $"{DateTime.Now}产品{productNumber}出列失败:true," + $"当前队列产品数量:{tmpDic.Count}"; this.BeginInvoke(new MethodInvoker(delegate () { int currentScrollPosition = richTextBox1.GetPositionFromCharIndex(richTextBox1.TextLength).Y; richTextBox1.AppendText(logStr); // 设置回原来的滚动位置 richTextBox1.SelectionStart = richTextBox1.TextLength; richTextBox1.ScrollToCaret(); })); } else { try { string logStr = $"{DateTime.Now}产品{productNumber}出列成功:true," + $"产品结果:{temp.ProductResult.GetEnumDescription()}," + $"当前队列产品数量:{tmpDic.Count}"; this.BeginInvoke(new MethodInvoker(delegate () { int currentScrollPosition = richTextBox1.GetPositionFromCharIndex(richTextBox1.TextLength).Y; richTextBox1.AppendText(logStr); // 设置回原来的滚动位置 richTextBox1.SelectionStart = richTextBox1.TextLength; richTextBox1.ScrollToCaret(); })); //重新生成实例 销毁之前的实例 var saveData = temp.GetProductData(); using (StreamWriter sw = new StreamWriter("D://123log.txt", true, Encoding.UTF8)) { sw.WriteLine(logStr); } } catch (Exception) { } finally { // temp.Dispose(); temp = null; } } // UpdateCT((float)(dtNow - _ctTime).TotalSeconds); //_ctTime = dtNow; // }); } catch (Exception ex) { //LogAsync(DateTime.Now, LogLevel.Error, $"流程检测未捕获的异常:{ex.GetExceptionMessage()}"); product?.Dispose(); } } }); } public void SetResult() { //// detectResult.IsPreTreatDone = detectResult.VisionImageSet.PreTreatedFlag ////2024-02-29 目标检测不能全是NG //if (IsPreTreatNG || IsObjectDetectNG) //{ // return; //} //if (IsPreTreatDone && IsMLDetectDone && IsAfterTreatDone) //{ // ResultState = ResultState.OK; // ResultLabel = ResultState.OK.GetEnumDescription(); //} } private void HandleStopButton() { Cameras.Clear(); Dectection.Clear(); // Add the code for the "停止" button click here // PLC.TurntableStop(); CurrentMachine = true; sLDMotion.Stop(); } public int UPH = 0; public void CalculateOEE() { TimeSpan timeSpan = DateTime.Now - startTime; UPH = (int)(ProductNum_Total / timeSpan.TotalHours) + 100; //UPM = (int)UPH / 60; this.BeginInvoke(new MethodInvoker(delegate () { label1.Text = UPH.ToString(); })); } private void HandleResetButton() { // Add the code for the "复位" button click here MessageBox.Show("复位按钮按下"); } private void HandleSettingsButton() { // Add the code for the "设置" button click here // MessageBox.Show("设置按钮按下"); List listCamBase = new List(); CameraBase cam1 = new CameraBase { CameraName = "Cam1", CameraIP = "192.168.1.101", SerialNumber = "1000001", Gain = 60, Exposure = 10, RotateImage = 0, isEnabled = false, }; CameraBase cam2 = new CameraBase { CameraName = "Cam2", CameraIP = "192.168.1.101", SerialNumber = "1000002", Gain = 60, Exposure = 10, RotateImage = 0, isEnabled = false, }; listCamBase.Add(cam1); listCamBase.Add(cam2); SettingWindow1 settingWindow = new SettingWindow1(); settingWindow.Show(); //s.cameras = listCamBase; //s.Show(); } private void HandleLoginButton() { // Add the code for the "登录" button click here MessageBox.Show("登录按钮按下"); } private void splitter1_SplitterMoved(object sender, SplitterEventArgs e) { } } }