From b27a2ba1ccbd8e2e7b61a700dde5f891ed6ae35d Mon Sep 17 00:00:00 2001 From: schangxiang@126.com <schangxiang@126.com> Date: 周五, 05 7月 2024 06:55:15 +0800 Subject: [PATCH] 233 --- DataCapture/iWare_SCADA_DataCapture/iWare_SCADA_BusinessLogical/BLL/WorkPieceInfoManager.cs | 229 +++++++++++++++++++++++++++++++++++++++++++++++++++++---- 1 files changed, 212 insertions(+), 17 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 eaae713..d277c64 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); @@ -495,7 +502,7 @@ } pieceInfo.WorkPieceinitOnlineTime = DateTimeHelper.GetDateTime(); pieceInfo.WorkingProcedurePlan = ConfigHelper.GetConfigString("WorkingProcedureAllStr") ?? "OP05OP10OP20OP30OP35OP40OP50OP60OP70OP80"; - pieceInfo.CreatedUserName = logMiddle.MonitoringPoint; + pieceInfo.CreatedUserName = ResetUpdatedUserName(logMiddle); pieceInfo.CreatedTime = DateTime.SpecifyKind(DateTime.Now, DateTimeKind.Local); pieceInfo.WorkingProcedureStartTime = DateTimeHelper.GetDateTime();// pieceInfo.WorkingProcedureEndTime = null; @@ -540,7 +547,7 @@ else {//鏇存柊宸ヤ欢 equinfo.WorkPieceID = logMiddle.WorkPieceID; - equinfo.UpdatedUserName = logMiddle.MonitoringPoint; + equinfo.UpdatedUserName = ResetUpdatedUserName(logMiddle); equinfo.UpdatedTime = DateTime.Now; equinfo.OnlineTime = DateTime.Now; } @@ -558,7 +565,7 @@ pieceInfo.QualityStateUpdateTime = logMiddle.UpdatedTime.Value.LocalDateTime; pieceInfo.QualityStateUpdateMode = QualityStateUpdateMode.Auto.ToString(); pieceInfo.Remarks = pieceInfo.Remarks ?? "" + $"{logMiddle.WorkingProcedure}璐ㄩ噺妫�娴嬪畬鎴愪慨鏀�"; - pieceInfo.UpdatedUserName = logMiddle.MonitoringPoint; + pieceInfo.UpdatedUserName = ResetUpdatedUserName(logMiddle); pieceInfo.UpdatedTime = DateTime.SpecifyKind(DateTime.Now, DateTimeKind.Local); if (!(pieceInfo.WorkingProcedureStartTime.HasValue && pieceInfo.WorkingProcedureStartTime > DateTime.Parse("1900/01/01"))) {//宸ュ簭寮�濮嬫椂闂存病鏈夊垯璧嬪�� @@ -625,21 +632,57 @@ qualityData.OP30QualityFilePathCH3 = logMiddle.OP30QualityFilePathCH3; qualityData.OP30QualityStateCH3 = logMiddle.QualityState.HasValue ? logMiddle.QualityState.Value.ToString() : "3"; qualityData.OP30QualityReceiveTimeCH3 = DateTimeHelper.GetDateTime(); + + if (qualityData.OP30QualityStateCH3 == ((int)QualityState.NG).ToString()) + { + logMiddle.QualityNoOk = (int)QualityNoOkEnum.OP30娑ㄦ柇宸ヤ綅鍔涚煩澶�; + logMiddle.QualityNoOkReason = QualityNoOkEnum.OP30娑ㄦ柇宸ヤ綅鍔涚煩澶�.ToString(); + //璧嬪�间笉鍚堟牸鍘熷洜 + SetQualityNoOk_WorkPieceInfo(logMiddle, ref pieceInfo); + } + break; case "OP3002CH4": qualityData.OP30QualityFilePathCH4 = logMiddle.OP30QualityFilePathCH4; qualityData.OP30QualityStateCH4 = logMiddle.QualityState.HasValue ? logMiddle.QualityState.Value.ToString() : "3"; qualityData.OP30QualityReceiveTimeCH4 = DateTimeHelper.GetDateTime(); + + if (qualityData.OP30QualityStateCH4 == ((int)QualityState.NG).ToString()) + { + logMiddle.QualityNoOk = (int)QualityNoOkEnum.OP30棰勬嫥绱у伐浣嶅姏鐭╁ぇ; + logMiddle.QualityNoOkReason = QualityNoOkEnum.OP30棰勬嫥绱у伐浣嶅姏鐭╁ぇ.ToString(); + //璧嬪�间笉鍚堟牸鍘熷洜 + SetQualityNoOk_WorkPieceInfo(logMiddle, ref pieceInfo); + } + break; case "OP3002CH5": qualityData.OP30QualityFilePathCH5 = logMiddle.OP30QualityFilePathCH5; qualityData.OP30QualityStateCH5 = logMiddle.QualityState.HasValue ? logMiddle.QualityState.Value.ToString() : "3"; qualityData.OP30QualityReceiveTimeCH5 = DateTimeHelper.GetDateTime(); + + if (qualityData.OP30QualityStateCH5 == ((int)QualityState.NG).ToString()) + { + logMiddle.QualityNoOk = (int)QualityNoOkEnum.OP30缁堟嫥绱у伐浣嶅姏鐭╁ぇ; + logMiddle.QualityNoOkReason = QualityNoOkEnum.OP30缁堟嫥绱у伐浣嶅姏鐭╁ぇ.ToString(); + //璧嬪�间笉鍚堟牸鍘熷洜 + SetQualityNoOk_WorkPieceInfo(logMiddle, ref pieceInfo); + } + break; case "OP3002CH6": qualityData.OP30QualityFilePathCH6 = logMiddle.OP30QualityFilePathCH6; qualityData.OP30QualityStateCH6 = logMiddle.QualityState.HasValue ? logMiddle.QualityState.Value.ToString() : "3"; qualityData.OP30QualityReceiveTimeCH6 = DateTimeHelper.GetDateTime(); + + if (qualityData.OP30QualityStateCH6 == ((int)QualityState.NG).ToString()) + { + logMiddle.QualityNoOk = (int)QualityNoOkEnum.OP30鍘嬭‖濂楀伐浣嶅姏鐭╁ぇ; + logMiddle.QualityNoOkReason = QualityNoOkEnum.OP30鍘嬭‖濂楀伐浣嶅姏鐭╁ぇ.ToString(); + //璧嬪�间笉鍚堟牸鍘熷洜 + SetQualityNoOk_WorkPieceInfo(logMiddle, ref pieceInfo); + } + break; default: break; @@ -684,9 +727,9 @@ SetQualityNoOk_WorkPieceProcess(logMiddle, ref process); process.Id = Yitter.IdGenerator.YitIdHelper.NextId(); - process.CreatedUserName = logMiddle.MonitoringPoint; + process.CreatedUserName = ResetUpdatedUserName(logMiddle); process.CreatedTime = DateTime.SpecifyKind(DateTime.Now, DateTimeKind.Local); - process.UpdatedUserName = logMiddle.MonitoringPoint; + process.UpdatedUserName = ResetUpdatedUserName(logMiddle); process.UpdatedTime = DateTime.SpecifyKind(DateTime.Now, DateTimeKind.Local); process.OperationType = OperationType.鐢熶骇.ToString(); process.QualityDataInfoID = qualityData.Id; @@ -696,7 +739,7 @@ else {//鍏朵粬鐨勯兘鍙槸淇敼 pro.QualityDataInfoID = qualityData.Id; - pro.UpdatedUserName = logMiddle.MonitoringPoint; + pro.UpdatedUserName = ResetUpdatedUserName(logMiddle); pro.UpdatedTime = DateTimeHelper.GetDateTime(); pro.QualityState = pieceInfo.QualityState.HasValue ? pieceInfo.QualityState.Value : 9; //璧嬪�间笉鍚堟牸鍘熷洜 @@ -705,7 +748,7 @@ //TODO:鍒ゆ柇濡傛灉鏄�60宸ュ簭锛岄偅涔堝氨瑕佹洿鏂皃ro琛ㄧ殑鍒涘缓浜轰负loginfo.MonitoringPoint 銆怑ditby shaocx,2024-06-05銆� if (logMiddle.WorkingProcedure == "OP60") { - pro.CreatedUserName = logMiddle.MonitoringPoint; + pro.CreatedUserName = ResetUpdatedUserName(logMiddle); } } @@ -748,6 +791,21 @@ } } } + + /// <summary> + /// 璧嬪�� 淇敼浜� 銆怑ditby shaocx,2024-07-05銆� + /// </summary> + /// <param name="logMiddle"></param> + /// <returns></returns> + public static string ResetUpdatedUserName(WorkPieceLogMiddle logMiddle) + { + if (logMiddle.MonitoringPoint.Equals("OP1003")) + {//鍥犱负OP10鍜孫P40鏄竴鍙版満鍣紝OP1003涓撻棬鏄疧P40娴嬮噺鐨勩�� + return "OP4003"; + } + return logMiddle.MonitoringPoint; + } + /// <summary> /// 宸ヤ欢鎺ㄥ嚭NOOK /// </summary> @@ -2198,15 +2256,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; @@ -2245,36 +2323,153 @@ } return qualityState; } + 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)) + { + qualityNoOkEnum = QualityNoOkEnum.OP80澶уご瀛旂洿寰勮秴宸�; + } + + decimal _QualityOP80_X_TKZJ = SystemHelper.GetDecimal(logMiddle.QualityOP80_X_TKZJ); + if (!(_QualityOP80_X_TKZJ >= (decimal)22.005 && _QualityOP80_X_TKZJ <= (decimal)22.011)) + { + qualityNoOkEnum = QualityNoOkEnum.OP80灏忓ご瀛旂洿寰勮秴宸�; + } + + decimal _QualityOP80_ZXJ = SystemHelper.GetDecimal(logMiddle.QualityOP80_ZXJ); + if (!(_QualityOP80_ZXJ >= (decimal)144.475 && _QualityOP80_ZXJ <= (decimal)144.525)) + { + qualityNoOkEnum = QualityNoOkEnum.OP80涓績璺濊秴宸�; + } + + decimal _QualityOP80_DTKYZD = SystemHelper.GetDecimal(logMiddle.QualityOP80_DTKYZD); + if (!(_QualityOP80_DTKYZD >= (decimal)0 && _QualityOP80_DTKYZD <= (decimal)0.005)) + { + qualityNoOkEnum = QualityNoOkEnum.OP80澶уご瀛斿渾鏌卞害瓒呭樊; + } + + decimal _QualityOP80_XTSMYD = SystemHelper.GetDecimal(logMiddle.QualityOP80_XTSMYD); + if (!(_QualityOP80_XTSMYD >= (decimal)0 && _QualityOP80_XTSMYD <= (decimal)0.003)) + { + qualityNoOkEnum = QualityNoOkEnum.OP80灏忓ご瀛斿渾搴︿笂闈㈣秴宸�; + } + + decimal _QualityOP80_XTXMYD = SystemHelper.GetDecimal(logMiddle.QualityOP80_XTXMYD); + if (!(_QualityOP80_XTXMYD >= (decimal)0 && _QualityOP80_XTXMYD <= (decimal)0.003)) + { + qualityNoOkEnum = QualityNoOkEnum.OP80灏忓ご瀛斿渾搴︿笅闈㈣秴宸�; + } + + decimal _QualityOP80To4 = SystemHelper.GetDecimal(logMiddle.QualityOP80To4); + if (!(_QualityOP80To4 >= (decimal)(-0.075) && _QualityOP80To4 <= (decimal)0.075)) + { + qualityNoOkEnum = QualityNoOkEnum.OP80灏忓ご瀛斿钩琛屽害寮洸瓒呭樊; + } + + decimal _QualityOP80To5 = SystemHelper.GetDecimal(logMiddle.QualityOP80To5); + if (!(_QualityOP80To5 >= (decimal)(-0.2) && _QualityOP80To5 <= (decimal)0.2)) + { + qualityNoOkEnum = QualityNoOkEnum.OP80灏忓ご瀛斿钩琛屽害鎵洸瓒呭樊; + } + + decimal _QualityOP80To6 = SystemHelper.GetDecimal(logMiddle.QualityOP80To6); + if (!(_QualityOP80To6 >= (decimal)0 && _QualityOP80To6 <= (decimal)0.04)) + { + qualityNoOkEnum = QualityNoOkEnum.OP80澶уご瀛斿瀭鐩村害瓒呭樊; + } + + decimal _QualityOP80To10 = SystemHelper.GetDecimal(logMiddle.QualityOP80To10); + if (!(_QualityOP80To10 >= (decimal)0 && _QualityOP80To10 <= (decimal)0.04)) + { + qualityNoOkEnum = QualityNoOkEnum.OP80灏忓ご瀛斿瀭鐩村害瓒呭樊; + } + + decimal _QualityOP80_Houdu = SystemHelper.GetDecimal(logMiddle.QualityOP80_Houdu); + if (!(_QualityOP80_Houdu >= (decimal)21.80 && _QualityOP80_Houdu <= (decimal)21.85)) + { + qualityNoOkEnum = QualityNoOkEnum.OP80鍘氬害瓒呭樊; + } + + decimal _QualityOP80To1 = SystemHelper.GetDecimal(logMiddle.QualityOP80To1); + if (!(_QualityOP80To1 >= (decimal)364 && _QualityOP80To1 <= (decimal)385)) + { + qualityNoOkEnum = QualityNoOkEnum.OP80澶уご绔噸閲忚秴宸�; + } + + decimal _QualityOP80To2 = SystemHelper.GetDecimal(logMiddle.QualityOP80To2); + if (!(_QualityOP80To2 >= (decimal)143 && _QualityOP80To2 <= (decimal)155)) + { + qualityNoOkEnum = QualityNoOkEnum.OP80灏忓ご绔噸閲忚秴宸�; + } + + + return qualityState; + } else if (logMiddle.WorkingProcedure == "OP10") - { - if (logMiddle.QualityState != (int)QualityState.OK) + {//鍚堟牸/涓嶅悎鏍肩敱 QualityStateStr鍊煎垽鏂� + if (logMiddle.QualityState == (int)QualityState.NG) { qualityNoOkEnum = QualityNoOkEnum.OP10鍘氬害瓒呭樊; + } + else + { + qualityState = QualityState.OK; } return qualityState; } else if (logMiddle.WorkingProcedure == "OP20") - { - if (logMiddle.QualityState != (int)QualityState.OK) + {//鍚堟牸/涓嶅悎鏍肩敱 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") - { - if (logMiddle.QualityState != (int)QualityState.OK) + {//鍚堟牸/涓嶅悎鏍肩敱 QualityStateStr鍊煎垽鏂� + if (logMiddle.QualityState == (int)QualityState.NG) { qualityNoOkEnum = QualityNoOkEnum.OP35婊氬帇鍔涗笉鍚堟牸; + } + else + { + qualityState = QualityState.OK; } return qualityState; } else if (logMiddle.WorkingProcedure == "OP40") - { - if (logMiddle.QualityState != (int)QualityState.OK) + {//鍚堟牸/涓嶅悎鏍肩敱 QualityStateStr鍊煎垽鏂� + if (logMiddle.QualityState == (int)QualityState.NG) { qualityNoOkEnum = QualityNoOkEnum.OP40鍘氬害瓒呭樊; } + else + { + qualityState = QualityState.OK; + } return qualityState; } return qualityState; -- Gitblit v1.9.3