From 1daeb924fb62c47ae8fc4f9fed710d19b8ea113e Mon Sep 17 00:00:00 2001 From: schangxiang@126.com <schangxiang@126.com> Date: 周四, 12 12月 2024 14:48:34 +0800 Subject: [PATCH] 22 --- CC/iWareCC_ASRS/ThreadService/04_BZ21(搬运整垛机器人)/1、DataProcess_BZ21.cs | 118 +++++++++++++++++++++++++++++++++-------------------------- 1 files changed, 66 insertions(+), 52 deletions(-) diff --git "a/CC/iWareCC_ASRS/ThreadService/04_BZ21\357\274\210\346\220\254\350\277\220\346\225\264\345\236\233\346\234\272\345\231\250\344\272\272\357\274\211/1\343\200\201DataProcess_BZ21.cs" "b/CC/iWareCC_ASRS/ThreadService/04_BZ21\357\274\210\346\220\254\350\277\220\346\225\264\345\236\233\346\234\272\345\231\250\344\272\272\357\274\211/1\343\200\201DataProcess_BZ21.cs" index 676369f..78fb444 100644 --- "a/CC/iWareCC_ASRS/ThreadService/04_BZ21\357\274\210\346\220\254\350\277\220\346\225\264\345\236\233\346\234\272\345\231\250\344\272\272\357\274\211/1\343\200\201DataProcess_BZ21.cs" +++ "b/CC/iWareCC_ASRS/ThreadService/04_BZ21\357\274\210\346\220\254\350\277\220\346\225\264\345\236\233\346\234\272\345\231\250\344\272\272\357\274\211/1\343\200\201DataProcess_BZ21.cs" @@ -10,6 +10,7 @@ using iWareSql.WmsDBModel; using Newtonsoft.Json.Linq; using System; +using System.Collections; using System.Collections.Generic; using System.ComponentModel; using System.Diagnostics.Contracts; @@ -22,7 +23,7 @@ { public class DataProcess_BZ21 { - public static void Hander() + public static async void Hander() { var alertMsg = ""; LogType logType = LogType.DataProcess_BZ21; @@ -88,7 +89,7 @@ //澧炲姞鏍¢獙锛屽鏋滀笂涓�涓换鍔pi璺熸湰娆pi涓�鑷达紝灏辨姤閿� 銆怑ditby shaocx,2024-12-03銆� var lastTask = wmsDB.wms_rbline_task.Where(x => x.RbTaskType == (int)RbTaskTypeEnum.鍚堝寘浠诲姟).OrderByDescending(x => x.Id).FirstOrDefault(); - if (lastTask != null && lastTask.UPI == result) + if (lastTask != null && lastTask.Upi == result) { SystemWarningMsg._lbl_alert_DataProcess_BZ21 = $"{rgvLocation.ToString()}-PLC閲嶅彂姝や换鍔★紝upi锛歿result}锛岀郴缁熶笉鑳介噸澶嶅鐞�,姝ゆ寰幆缁撴潫"; continue; @@ -97,13 +98,20 @@ var upiObj = wmsDB.mes_batchOrderUPI_new.Where(x => x.UPI == result).FirstOrDefault(); if (upiObj == null) { + //鍐欏叆鎶ヨ淇℃伅 + await MyExtendHelper.WriteBoolPlcDataForWarning(PlcWarningAddressGloble.Num_BZ21_1); + SystemWarningMsg._lbl_alert_DataProcess_BZ21 = $"{rgvLocation.ToString()},鏍规嵁UPI:{result}娌℃湁鎵惧埌瀵硅薄 "; continue; } + //楠岃瘉鏄惁鍏佽鍒囩焊 var validteReslt = ValidateIsAllowCut(); if (validteReslt == false) { + //鍐欏叆鎶ヨ淇℃伅 + await MyExtendHelper.WriteBoolPlcDataForWarning(PlcWarningAddressGloble.Num_BZ21_2); + continue; } @@ -114,50 +122,72 @@ papercut.ApiMessage = ""; papercut.PushNum = 0; papercut.PushStatus = (int)PushStatusEnum.NotPush; + papercut.CreateUserName = papercut.UpdateUserName = SysGloble.WCSSystem; papercut.CreateTime = papercut.UpdateTime = DateTime.Now; wmsDB.mes_push_papercut.Add(papercut); + + + AreaCodeEnum setAreaCode = AreaCodeEnum.鍚堝寘瑁佸垏鍖�; + UpiStatusEnum setUpiStatus = UpiStatusEnum.宸插悎鍖�; + + var ngFlag = false; + var queryFlag = (int)UpiFlagEnum.NG; + var upilist = wmsDB.mes_batchOrderUPI_new.Where(x => x.PackageCode == upiObj.PackageCode).ToList(); + var ngCount = upilist.Count(x => x.UpiFlag == queryFlag); + if (ngCount > 0) + { + ngFlag = true; + setUpiStatus = UpiStatusEnum.宸蹭笅绾�; + setAreaCode = AreaCodeEnum.涓嬬嚎鍖哄煙; + } + else + {//涓嶆槸NG + //鏂板mes鎺ㄩ�佽〃 + var putpakegecodeid = Yitter.IdGenerator.YitIdHelper.NextId(); + var putpakegecode = new mes_push_packagecode() + { + Id = putpakegecodeid, + PackageCode = upiObj.PackageCode, + PushStatus = 0, + PushNum = 0, + ApiMessage = "", + CreateTime = DateTime.Now, + CreateUserName = SysGloble.WCSSystem, + UpdateTime = DateTime.Now, + UpdateUserName = SysGloble.WCSSystem + + }; + wmsDB.mes_push_packagecode.Add(putpakegecode); + + //鏂板琛� + var mesinequeue = ClassHelper.RotationMapping<mes_package_linequeue, mes_batchOrderUPI_new>(upiObj); + mesinequeue.Id = Yitter.IdGenerator.YitIdHelper.NextId(); + mesinequeue.CreateTime = mesinequeue.UpdateTime = DateTime.Now; + wmsDB.mes_package_linequeue.Add(mesinequeue); + } //鏇存柊琛� var mesgather = wmsDB.mes_package_gather.Where(x => x.PackageCode == upiObj.PackageCode).FirstOrDefault(); if (mesgather != null) { - mesgather.AreaCode = (int)AreaCodeEnum.鍚堝寘瑁佸垏鍖�; - mesgather.UpiStatus = (int)UpiStatusEnum.宸插悎鍖�; + mesgather.AreaCode = (int)setAreaCode; + mesgather.UpiStatus = (int)setUpiStatus; } - //var upilist = wmsDB.mes_batchOrderUPI_new.Where(x => x.PackageCode == upiObj.PackageCode).ToList(); - //var upilength = upilist.Max(x => x.Length); - //var upiwidth = upilist.Max(x => x.Width); - //cartonhigh = (short)upiObj.Info3; - //cartonwidth = (short)upiObj.Info2; - upiObj.UpiStatus = (int)UpiStatusEnum.宸插悎鍖�; - upiObj.AreaCode = (int)AreaCodeEnum.鍚堝寘瑁佸垏鍖�; + + upiObj.UpiStatus = (int)setUpiStatus; + upiObj.AreaCode = (int)setAreaCode; //璁板綍浠诲姟 var _id = Yitter.IdGenerator.YitIdHelper.NextId(); - var putpakegecodeid = Yitter.IdGenerator.YitIdHelper.NextId(); - var plcTaskNo = BusinessHelper.CreatePlcTaskIdForSrmTask(); - //鏂板琛� - var mesinequeue = ClassHelper.RotationMapping<mes_package_linequeue, mes_batchOrderUPI_new>(upiObj); - mesinequeue.Id = Yitter.IdGenerator.YitIdHelper.NextId(); - //鏂板mes鎺ㄩ�佽〃 - var putpakegecode = new mes_push_packagecode() - { - Id = putpakegecodeid, - PackageCode = upiObj.PackageCode, - PushStatus = 0, - PushNum = 0, - ApiMessage = "", - CreateTime = DateTime.Now, - CreateUserName = "CC", - UpdateTime = DateTime.Now, - UpdateUserName = "CC", - }; + var plcTaskNo = BusinessHelper.CreatePlcTaskIdForSrmTask(); + + //鏂板浠诲姟琛� var task = new wms_rbline_task() { Id = _id, TaskNo = plcTaskNo, - UPI = upiObj.UPI, + Upi = upiObj.UPI, Length = upiObj.Length, Width = upiObj.Width, Thk = upiObj.Thk, @@ -166,9 +196,7 @@ OrderId = upiObj.OrderId, PackageCode = upiObj.PackageCode, RbTaskType = (int)RbTaskTypeEnum.鍚堝寘浠诲姟, - RbTaskTypeEnumName = RbTaskTypeEnum.鍚堝寘浠诲姟.ToString(), TaskStatus = (int)TaskStatusEnum.鏂板缓, - TaskStatusName = TaskStatusEnum.鏂板缓.ToString(), TaskMsg = "澶规澘", CreateTime = DateTime.Now, CreateUserName = "CC", @@ -199,9 +227,9 @@ printtwo.Id = Yitter.IdGenerator.YitIdHelper.NextId(); wmsDB.wms_record_print.Add(printtwo); - wmsDB.mes_package_linequeue.Add(mesinequeue); + wmsDB.wms_rbline_task.Add(task); - wmsDB.mes_push_packagecode.Add(putpakegecode); + //澶勭悊琛� mes_order_gather var errmsg = ""; @@ -213,24 +241,6 @@ continue; } - /* - using (StationServiceClient client = new StationServiceClient()) - { - - var plcres = client.WriteSurroundTaskInfo((int)EDevice.Station, rgvLocation, short.Parse(task.TaskNo), - (short)upilength, (short)upiwidth, cartonhigh, cartonwidth, 0, 0); - if (!plcres.result) - { - SystemWarningMsg._lbl_alert_DataProcess_BZ12 = $"{rgvLocation.ToString()}-涓嬪彂鍏ュ簱浠诲姟 澶辫触,WriteInStoreTaskInfoAsync 杩斿洖:{plcres.resMsg}"; - continue; - } - else - { - Log4NetHelper.WriteInfoLog(logType, $"{rgvLocation.ToString()}-涓嬪彂鍏ュ簱浠诲姟 鎴愬姛,WriteInStoreTaskInfoAsync锛屽弬鏁�: 绔欑偣{rgvLocation}"); - } - } - //*/ - WmsRecordUpiProcessHandler.SaveWmsRecordUpiProcess(wmsDB, upiObj, "BZ21", "鍚堝寘"); WmsRecordUpiProcessHandler.SaveWmsRecordPackageProcess(wmsDB, upiObj, "BZ21", "鍚堝寘"); @@ -238,6 +248,10 @@ wmsDB.SaveChanges(); } } + else + { + SystemWarningMsg._lbl_Alert_DataProcess_BZ21 = $"{rgvLocation.ToString()}-娌℃湁瑕佸鐞嗙殑鏁版嵁"; + } } } catch (Exception ex) -- Gitblit v1.9.3