From 1b57ab89964f191e3986921270f58eb5bf34d954 Mon Sep 17 00:00:00 2001
From: schangxiang@126.com <schangxiang@126.com>
Date: 周三, 03 7月 2024 14:58:28 +0800
Subject: [PATCH] 222

---
 DataCapture/iWare_SCADA_DataCapture/iWare_SCADA_BusinessLogical/BLL/WorkPieceInfoManager.cs |   81 +++++++++++++++++++++++++++++++++++-----
 1 files changed, 71 insertions(+), 10 deletions(-)

diff --git a/DataCapture/iWare_SCADA_DataCapture/iWare_SCADA_BusinessLogical/BLL/WorkPieceInfoManager.cs b/DataCapture/iWare_SCADA_DataCapture/iWare_SCADA_BusinessLogical/BLL/WorkPieceInfoManager.cs
index 55d645a..5d957e3 100644
--- a/DataCapture/iWare_SCADA_DataCapture/iWare_SCADA_BusinessLogical/BLL/WorkPieceInfoManager.cs
+++ b/DataCapture/iWare_SCADA_DataCapture/iWare_SCADA_BusinessLogical/BLL/WorkPieceInfoManager.cs
@@ -226,7 +226,14 @@
                         WorkPieceProcess process = new WorkPieceProcess();
                         process = EntityPropHelper.Mapper<WorkPieceProcess, WorkPieceInfo>(info);
                         process.StartTime = DateTimeHelper.GetDateTime();
+
                         process.QualityState = info.QualityState.HasValue ? info.QualityState.Value : (int)QualityState.OK;
+
+                        if (process.WorkingProcedureCurrent == WorkingProcedureForHMI.OP70.ToString())
+                        { //鐗规畩澶勭悊OP70锛屽洜涓篛P70娌℃湁娴嬮噺锛岄粯璁ゅ悎鏍� [Editby shaocx,2024-07-03]
+                            process.QualityState = (int)QualityState.OK;
+                        }
+
                         process.Id = Yitter.IdGenerator.YitIdHelper.NextId();
                         process.CreatedUserName = loginfo.MonitoringPoint;
                         process.CreatedTime = DateTime.SpecifyKind(DateTime.Now, DateTimeKind.Local);
@@ -2234,15 +2241,35 @@
             return loginfo;
         }
 
+        /// <summary>
+        /// 璁剧疆涓棿鍙橀噺鐨勮川閲忔暟鎹�
+        /// </summary>
+        /// <param name="logMiddle"></param>
+        public static void SetLogMiddleForQuality(ref WorkPieceLogMiddle logMiddle)
+        {
+
+            logMiddle.QualityState = (int)((logMiddle.QualityStateStr.Equals("OK") || logMiddle.QualityStateStr.Equals("0K")) ? QualityState.OK : QualityState.NG);
+
+            //鏍规嵁璐ㄩ噺鏁版嵁鍒ゆ柇鏄惁鍚堟牸/涓嶅悎鏍� 銆怑ditby shaocx,2024-06-25銆�
+            QualityNoOkEnum? qualityNoOkEnum = null;
+            QualityState qualityState = WorkPieceInfoManager.CalcQualityStateForOP(logMiddle, ref qualityNoOkEnum);
+            logMiddle.QualityState = (int)qualityState;
+            logMiddle.QualityStateStr = qualityState.ToString();
+            if (qualityNoOkEnum != null)
+            {
+                logMiddle.QualityNoOk = (int)qualityNoOkEnum;
+                logMiddle.QualityNoOkReason = qualityNoOkEnum.ToString();
+            }
+        }
 
         /// <summary>
         /// 璁$畻OP 璐ㄩ噺鏁版嵁鏄惁鍚堟牸
         /// </summary>
-        public static QualityState CalcQualityStateForOP(WorkPieceLogMiddle logMiddle, ref QualityNoOkEnum? qualityNoOkEnum)
+        private static QualityState CalcQualityStateForOP(WorkPieceLogMiddle logMiddle, ref QualityNoOkEnum? qualityNoOkEnum)
         {
             QualityState qualityState = QualityState.Suspected;
             if (logMiddle.WorkingProcedure == "OP60")
-            {
+            {//鍚堟牸/涓嶅悎鏍肩敱 WMS鑷鍒ゆ柇
                 decimal _QualityOP60To1 = SystemHelper.GetDecimal(logMiddle.QualityOP60To1);
                 decimal _QualityOP60To2 = SystemHelper.GetDecimal(logMiddle.QualityOP60To2);
                 var isPass_QualityOP60To1 = false;
@@ -2281,8 +2308,14 @@
                 }
                 return qualityState;
             }
-            if (logMiddle.WorkingProcedure == "OP80")
-            {
+            else if (logMiddle.WorkingProcedure == "OP80")
+            {//鍚堟牸/涓嶅悎鏍肩敱 OP80 鍒ゆ柇锛孮ualityState 鍜� QualityStateStr 閮藉湪璋冪敤褰撳墠鏂规硶鍓� 鍐欏叆鍊间簡
+                if (logMiddle.QualityState == (int)QualityState.OK)
+                {
+                    qualityState = QualityState.OK;
+                    return qualityState;
+                }
+
                 decimal _QualityOP80_D_TKZJ = SystemHelper.GetDecimal(logMiddle.QualityOP80_D_TKZJ);
                 if (!(_QualityOP80_D_TKZJ >= (decimal)53.018 && _QualityOP80_D_TKZJ <= (decimal)53.03))
                 {
@@ -2320,13 +2353,13 @@
                 }
 
                 decimal _QualityOP80To4 = SystemHelper.GetDecimal(logMiddle.QualityOP80To4);
-                if (!(_QualityOP80To4 >= (decimal)0 && _QualityOP80To4 <= (decimal)0.075))
+                if (!(_QualityOP80To4 >= (decimal)(-0.075) && _QualityOP80To4 <= (decimal)0.075))
                 {
                     qualityNoOkEnum = QualityNoOkEnum.OP80灏忓ご瀛斿钩琛屽害寮洸瓒呭樊;
                 }
 
                 decimal _QualityOP80To5 = SystemHelper.GetDecimal(logMiddle.QualityOP80To5);
-                if (!(_QualityOP80To5 >= (decimal)0 && _QualityOP80To5 <= (decimal)0.2))
+                if (!(_QualityOP80To5 >= (decimal)(-0.2) && _QualityOP80To5 <= (decimal)0.2))
                 {
                     qualityNoOkEnum = QualityNoOkEnum.OP80灏忓ご瀛斿钩琛屽害鎵洸瓒呭樊;
                 }
@@ -2365,35 +2398,63 @@
                 return qualityState;
             }
             else if (logMiddle.WorkingProcedure == "OP10")
-            {
+            {//鍚堟牸/涓嶅悎鏍肩敱 QualityStateStr鍊煎垽鏂�
                 if (logMiddle.QualityState == (int)QualityState.NG)
                 {
                     qualityNoOkEnum = QualityNoOkEnum.OP10鍘氬害瓒呭樊;
                 }
+                else
+                {
+                    qualityState = QualityState.OK;
+                }
                 return qualityState;
             }
             else if (logMiddle.WorkingProcedure == "OP20")
-            {
+            {//鍚堟牸/涓嶅悎鏍肩敱 QualityStateStr鍊煎垽鏂�
                 if (logMiddle.QualityState == (int)QualityState.NG)
                 {
                     qualityNoOkEnum = QualityNoOkEnum.OP20灏忓ご瀛旂洿寰勮秴宸�;
                 }
+                else
+                {
+                    qualityState = QualityState.OK;
+                }
+                return qualityState;
+            }
+            else if (logMiddle.WorkingProcedure == "OP30")
+            {//鍚堟牸/涓嶅悎鏍肩敱 QualityStateStr鍊煎垽鏂�
+                if (logMiddle.QualityStateStr.Equals("OK"))
+                {
+                    qualityState = QualityState.OK;
+                }
+                else
+                {
+                    qualityState = QualityState.NG;
+                }
                 return qualityState;
             }
             else if (logMiddle.WorkingProcedure == "OP35")
-            {
+            {//鍚堟牸/涓嶅悎鏍肩敱 QualityStateStr鍊煎垽鏂�
                 if (logMiddle.QualityState == (int)QualityState.NG)
                 {
                     qualityNoOkEnum = QualityNoOkEnum.OP35婊氬帇鍔涗笉鍚堟牸;
                 }
+                else
+                {
+                    qualityState = QualityState.OK;
+                }
                 return qualityState;
             }
             else if (logMiddle.WorkingProcedure == "OP40")
-            {
+            {//鍚堟牸/涓嶅悎鏍肩敱 QualityStateStr鍊煎垽鏂�
                 if (logMiddle.QualityState == (int)QualityState.NG)
                 {
                     qualityNoOkEnum = QualityNoOkEnum.OP40鍘氬害瓒呭樊;
                 }
+                else
+                {
+                    qualityState = QualityState.OK;
+                }
                 return qualityState;
             }
             return qualityState;

--
Gitblit v1.9.3