From 9d05b4e5a7b667afb6d13cbcb460e377c175c170 Mon Sep 17 00:00:00 2001
From: xcd <834800634@qq.com>
Date: 星期三, 01 七月 2020 19:44:26 +0800
Subject: [PATCH] 添加M071主界面和标签指示,

---
 src/Bro.M071.Process/M071Process.cs |   26 +++++++++++++++++++-------
 1 files changed, 19 insertions(+), 7 deletions(-)

diff --git a/src/Bro.M071.Process/M071Process.cs b/src/Bro.M071.Process/M071Process.cs
index 2667c4f..0c615a6 100644
--- a/src/Bro.M071.Process/M071Process.cs
+++ b/src/Bro.M071.Process/M071Process.cs
@@ -154,6 +154,8 @@
             }
         }
 
+        List<ProductionMeasurement> productionList = new List<ProductionMeasurement>();
+
         [ProcessMethod("", "StartJob", "寮�濮嬫壂鎻�", InvokeType.TestInvoke)]
         public ProcessResponse StartJob(IOperationConfig opConfig, IDevice invokeDevice, IDevice sourceDevice)
         {
@@ -175,6 +177,16 @@
                 Barcode = BarCode,
                 Measurements = measurements,
             };
+
+            var existedProduction = productionList.FirstOrDefault(u => u.Barcode == pMeasure.Barcode);
+            if (existedProduction != null)
+            {
+                productionList.Remove(existedProduction);
+                existedProduction.Dispose();
+                existedProduction = null;
+            }
+
+            productionList.Add(pMeasure);
 
             pMeasure.InitialMeasurementsPropertyChanged();
             pMeasure.PropertyChanged += MeasureProduction_PropertyChanged;
@@ -200,10 +212,6 @@
                       CameraBase camera = DeviceCollection.FirstOrDefault(u => u.Id == s.CameraOp.Device) as CameraBase;
                       if (camera == null)
                           return;
-
-                      //IImageSet imgSet = camera.Snapshot(s.CameraOp.OpConfig);
-                      //if (imgSet == null)
-                      //    return;
 
                       HImage hImage = CollectHImage(camera, s.CameraOp.OpConfig, out string imgSetId);
                       if (string.IsNullOrWhiteSpace(imgSetId))
@@ -294,8 +302,12 @@
                                     }
                                 }
 
+                                LogAsync(DateTime.Now, $"{m.GetDisplayText()}妫�娴嬬粨鏋�", $"{((m.Spec.MeasureResult ?? false) ? "OK" : "NG")}");
+
+                                IShapeElement indicator = null;
+                                pMeasure.ElementList.Add(indicator);
                                 //杈撳嚭鍥惧舰鍩哄厓鍒扮晫闈� todo
-                                OnElementUpdated?.BeginInvoke(null, null, null);
+                                OnElementUpdated?.BeginInvoke(indicator, null, null);
 
                                 SaveKeyImages(pMeasure.Barcode, m);
 
@@ -309,8 +321,6 @@
                         return;
                     }
 
-
-
                     //MES杈撳嚭 todo
 
                     //Excel鎶ヨ〃杈撳嚭 todo
@@ -318,6 +328,8 @@
                     //鏁版嵁搴撲繚瀛� todo
 
                     SaveWholeImage(pMeasure);
+
+                    productionList.RemoveAll(p => p.Barcode == pMeasure.Barcode);
                     pMeasure.Dispose();
                 }
             }

--
Gitblit v1.8.0