From 5bf1b91009a182188d6d2245aa71653801eea60b Mon Sep 17 00:00:00 2001
From: wells <123>
Date: 星期日, 12 七月 2020 18:09:54 +0800
Subject: [PATCH] debug

---
 src/Bro.M071.Process/UI/M071_MainForm.cs |  190 ++++++++++++++++++++++++++++-------------------
 1 files changed, 113 insertions(+), 77 deletions(-)

diff --git a/src/Bro.M071.Process/UI/M071_MainForm.cs b/src/Bro.M071.Process/UI/M071_MainForm.cs
index 17b79c9..e875fd6 100644
--- a/src/Bro.M071.Process/UI/M071_MainForm.cs
+++ b/src/Bro.M071.Process/UI/M071_MainForm.cs
@@ -53,38 +53,44 @@
             if (string.IsNullOrWhiteSpace(Config.BackgroundImagePath))
                 return;
 
-            this.Invoke(new Action(() =>
+            try
             {
-                try
-                {
-                    Bitmap image = (Bitmap)Image.FromFile(Config.BackgroundImagePath);
-                    cvImage.LoadImage(image);
-                    cvImage.SetScreenSize();
-                }
-                catch (Exception ex)
-                {
-                    LogAsync(new LogMsg(DateTime.Now, "杞藉叆鑳屾櫙鍥惧紓甯�", ex.Message));
-                    return;
-                }
+                this.Invoke(new Action(() =>
+                   {
+                       try
+                       {
+                           Bitmap image = (Bitmap)Image.FromFile(Config.BackgroundImagePath);
+                           cvImage.LoadImage(image);
+                           cvImage.SetScreenSize();
+                       }
+                       catch (Exception ex)
+                       {
+                           LogAsync(new LogMsg(DateTime.Now, "杞藉叆鑳屾櫙鍥惧紓甯�", ex.Message));
+                           return;
+                       }
 
-                cvImage.Elements.Clear();
-                lvMeasures.Items.Clear();
+                       cvImage.Elements.Clear();
+                       lvMeasures.Items.Clear();
 
-                txtBarcode.Enabled = !Config.IsBarcodeManualInputBlocked;
+                       txtBarcode.Enabled = !Config.IsBarcodeManualInputBlocked;
 
-                Config.MeasurementUnitCollection.ForEach(u =>
-                {
-                    if (!u.IsEnabled)
-                        return;
+                       Config.MeasurementUnitCollection.ForEach(u =>
+                       {
+                           if (!u.IsEnabled)
+                               return;
 
-                    var ele = new KeyIndicator(u.Id, u.DisplayLocation);
-                    cvImage.Elements.Add(ele);
+                           var ele = new KeyIndicator(u.Id, u.DisplayLocation);
+                           cvImage.Elements.Add(ele);
 
-                    ListViewItem item = new ListViewItem(u.GetDisplayText());
-                    item.Tag = u.Id;
-                    lvMeasures.Items.Add(item);
-                });
-            }));
+                           ListViewItem item = new ListViewItem(u.GetDisplayText());
+                           item.Tag = u.Id;
+                           lvMeasures.Items.Add(item);
+                       });
+                   }));
+            }
+            catch (Exception ex)
+            {
+            }
 
             Process_M071.OnClearBarcode -= M071_MainForm_OnClearBarcode;
             Process_M071.OnClearBarcode += M071_MainForm_OnClearBarcode;
@@ -104,6 +110,9 @@
 
             Config.PropertyChanged -= Config_PropertyChanged;
             Config.PropertyChanged += Config_PropertyChanged;
+
+            Process_M071.OnElementUpdated -= Process_M071_OnElementUpdated;
+            Process_M071.OnElementUpdated += Process_M071_OnElementUpdated;
         }
 
         private void Config_PropertyChanged(object sender, PropertyChangedEventArgs e)
@@ -223,6 +232,26 @@
         }
         #endregion
 
+        #region 鏍囩缁撴灉鏄剧ず
+        private async void Process_M071_OnElementUpdated(Common.Interface.IShapeElement obj)
+        {
+            if (obj is KeyIndicator keyIndicator)
+            {
+                this.Invoke(new Action(() =>
+                {
+                    var ele = cvImage.Elements.FirstOrDefault(u => u.ID == keyIndicator.ID);
+
+                    (ele as KeyIndicator).Text = keyIndicator.Text;
+                    (ele as KeyIndicator).ResultState = keyIndicator.ResultState;
+
+                    this.Invalidate();
+                }));
+            }
+
+            await Task.Delay(100);
+        }
+        #endregion
+
         #region 涓婃柟鐘舵�佸尯
 
         #region 鏉$爜
@@ -261,46 +290,59 @@
         #region 鏈哄彴鐘舵��
         private async void M071_MainForm_MachineStateChanged(MachineState state)
         {
-            lblMachineState.BeginInvoke(new Action(() =>
+            if (lblMachineState.IsHandleCreated)
             {
-                switch (state)
+                lblMachineState.BeginInvoke(new Action(() =>
                 {
-                    case MachineState.Alarm:
-                        btnStartMeasure.BackColor = lblMachineState.BackColor = Color.Red;
-                        btnStartMeasure.ForeColor = lblMachineState.ForeColor = Color.White;
-                        lblMachineState.Text = "璀︽姤";
+                    switch (state)
+                    {
+                        case MachineState.Alarm:
+                            btnStartMeasure.BackColor = lblMachineState.BackColor = Color.Red;
+                            btnStartMeasure.ForeColor = lblMachineState.ForeColor = Color.White;
+                            lblMachineState.Text = "璀︽姤";
 
-                        btnStartMeasure.Enabled = false;
-                        break;
-                    case MachineState.Pause:
-                        btnStartMeasure.BackColor = lblMachineState.BackColor = Color.Yellow;
-                        btnStartMeasure.ForeColor = lblMachineState.ForeColor = Color.Black;
-                        lblMachineState.Text = "鏆傚仠";
+                            btnStartMeasure.Text = "寮�濮嬫祴閲�";
+                            btnStartMeasure.Enabled = false;
+                            btnStartMeasure.BackColor = Color.Red;
+                            break;
+                        case MachineState.Pause:
+                            btnStartMeasure.BackColor = lblMachineState.BackColor = Color.Yellow;
+                            btnStartMeasure.ForeColor = lblMachineState.ForeColor = Color.Black;
+                            lblMachineState.Text = "鏆傚仠";
 
-                        //btnStartMeasure.Text = "鏆傚仠娴嬮噺";
-                        btnStartMeasure.Enabled = true;
-                        break;
-                    case MachineState.Ready:
-                        btnStartMeasure.BackColor = lblMachineState.BackColor = Color.Lime;
-                        btnStartMeasure.ForeColor = lblMachineState.ForeColor = Color.White;
-                        lblMachineState.Text = "灏辩华";
+                            btnStartMeasure.Text = "缁х画娴嬮噺";
+                            btnStartMeasure.Enabled = true;
+                            btnStartMeasure.BackColor = Color.Lime;
+                            break;
+                        case MachineState.Ready:
+                            btnStartMeasure.BackColor = lblMachineState.BackColor = Color.Lime;
+                            btnStartMeasure.ForeColor = lblMachineState.ForeColor = Color.White;
+                            lblMachineState.Text = "灏辩华";
+                            
+                            btnStartMeasure.Text = "寮�濮嬫祴閲�";
+                            btnStartMeasure.Enabled = true;
+                            btnStartMeasure.BackColor = Color.Lime;
+                            break;
+                        case MachineState.Running:
+                            btnStartMeasure.BackColor = lblMachineState.BackColor = Color.Lime;
+                            btnStartMeasure.ForeColor = lblMachineState.ForeColor = Color.DarkGreen;
+                            lblMachineState.Text = "杩愯";
 
-                        btnStartMeasure.Enabled = true;
-                        break;
-                    case MachineState.Running:
-                        btnStartMeasure.BackColor = lblMachineState.BackColor = Color.Lime;
-                        btnStartMeasure.ForeColor = lblMachineState.ForeColor = Color.DarkGreen;
-                        lblMachineState.Text = "杩愯";
+                            btnStartMeasure.Text = "鏆傚仠娴嬮噺";
+                            btnStartMeasure.Enabled = true;
+                            btnStartMeasure.BackColor = Color.Lime;
+                            break;
+                        case MachineState.Unknown:
+                            btnStartMeasure.BackColor = lblMachineState.BackColor = SystemColors.Control;
+                            btnStartMeasure.ForeColor = lblMachineState.ForeColor = SystemColors.ControlText;
+                            lblMachineState.Text = "鏈煡";
 
-                        btnStartMeasure.Enabled = true;
-                        break;
-                    case MachineState.Unknown:
-                        btnStartMeasure.BackColor = lblMachineState.BackColor = SystemColors.Control;
-                        btnStartMeasure.ForeColor = lblMachineState.ForeColor = SystemColors.ControlText;
-                        lblMachineState.Text = "鏈煡";
-                        break;
-                }
-            }));
+                            btnStartMeasure.Enabled = false;
+                            btnStartMeasure.BackColor = Color.Red;
+                            break;
+                    }
+                }));
+            }
 
             await Task.Delay(100);
         }
@@ -333,7 +375,7 @@
                     lblProductionState.Text = "NG";
                 }
 
-                btnStartMeasure.Text = "寮�濮嬫祴閲�";
+                //btnStartMeasure.Text = "寮�濮嬫祴閲�";
             }));
             await Task.Delay(100);
         }
@@ -347,6 +389,15 @@
                 lblProductionState.Text = "娴嬭瘯涓�";
 
                 lblCT.Text = "";
+
+                cvImage.Elements.ToList().ForEach(e =>
+                {
+                    if (e is KeyIndicator indicator)
+                    {
+                        indicator.Text = "";
+                        indicator.ResultState = null;
+                    }
+                });
             }));
             await Task.Delay(100);
         }
@@ -356,9 +407,6 @@
 
         private async void btnStartMeasure_Click(object sender, EventArgs e)
         {
-            btnStartMeasure.Enabled = false;
-            bool isBreak = false;
-
             if (btnStartMeasure.Text == "寮�濮嬫祴閲�")
             {
                 await Task.Run(() =>
@@ -369,31 +417,19 @@
                     }
                     catch (Exception ex)
                     {
-                        isBreak = true;
-
                         LogAsync(DateTime.Now, "娴佺▼寮傚父", ex.Message);
                         Process_M071.ExceptionRaisedInMonitor(ex);
-
-                        btnStartMeasure.Text = "寮�濮嬫祴閲�";
-
                     }
                 });
-
-                if (!isBreak)
-                    btnStartMeasure.Text = "鏆傚仠娴嬮噺";
             }
             else if (btnStartMeasure.Text == "缁х画娴嬮噺")
             {
                 Process_M071.SwitchJobStatus(new OperationConfigBase() { InputPara = new List<int>() { 0 } }, null, null);
-                btnStartMeasure.Text = "鏆傚仠娴嬮噺";
             }
             else
             {
                 Process_M071.SwitchJobStatus(new OperationConfigBase() { InputPara = new List<int>() { 1 } }, null, null);
-                btnStartMeasure.Text = "缁х画娴嬮噺";
             }
-
-            btnStartMeasure.Enabled = true;
         }
 
         #region 澶嶄綅鎿嶄綔
@@ -414,7 +450,7 @@
                 Process_M071.Reset(null, null, null);
             }
 
-            Process_M071.ResetTimer.Change(-1, 1000 * 5);
+            Process_M071.ResetTimer.Change(1000 * 5, -1);
         }
 
         private void btnReset_MouseUp(object sender, MouseEventArgs e)

--
Gitblit v1.8.0