From cb58fdbdc4391136e7176210e3f1969606f11903 Mon Sep 17 00:00:00 2001 From: lss <Lss@HanInfo> Date: 星期四, 29 五月 2025 16:52:21 +0800 Subject: [PATCH] 合肥佳通 --- HH.WCS.Mobox3/HH.WCS.Mobox3.JiaTong/process/TaskProcess.cs | 161 ++++++++++++++++++++++++++++++++++++++++------------- 1 files changed, 121 insertions(+), 40 deletions(-) diff --git a/HH.WCS.Mobox3/HH.WCS.Mobox3.JiaTong/process/TaskProcess.cs b/HH.WCS.Mobox3/HH.WCS.Mobox3.JiaTong/process/TaskProcess.cs index 4ecd908..c5c8430 100644 --- a/HH.WCS.Mobox3/HH.WCS.Mobox3.JiaTong/process/TaskProcess.cs +++ b/HH.WCS.Mobox3/HH.WCS.Mobox3.JiaTong/process/TaskProcess.cs @@ -13,6 +13,7 @@ using System.IdentityModel.Protocols.WSTrust; using System.Linq; using System.Security.Cryptography; +using System.Threading; using static HH.WCS.JiaTong.api.ApiModel; using static HH.WCS.JiaTong.LISTA.process.HttpModel; @@ -32,15 +33,33 @@ var trayCarryCount = mst.N_CNTR_COUNT > 0 ? mst.N_CNTR_COUNT : 1; if (load) { - Console.WriteLine($"浠诲姟{mst.S_CODE} 璐т綅{mst.S_START_LOC}鍙栬揣瀹屾垚锛岃捣鐐硅В缁戝鍣▄mst.S_CNTR_CODE}"); - LogHelper.Info($"浠诲姟{mst.S_CODE} 璐т綅{mst.S_START_LOC}鍙栬揣瀹屾垚锛岃捣鐐硅В缁戝鍣▄mst.S_CNTR_CODE}"); - LocationHelper.UnBindingLoc(mst.S_START_LOC, mst.S_CNTR_CODE.Split(',').ToList()); + //Console.WriteLine($"浠诲姟{mst.S_CODE} 璐т綅{mst.S_START_LOC}鍙栬揣瀹屾垚锛岃捣鐐硅В缁戝鍣▄mst.S_CNTR_CODE}"); + + if (!string.IsNullOrEmpty(mst.S_CNTR_CODE)) + { + LogHelper.Info($"浠诲姟{mst.S_CODE} 璐т綅{mst.S_START_LOC}鍙栬揣瀹屾垚锛岃捣鐐硅В缁戝鍣▄mst.S_CNTR_CODE}"); + LocationHelper.UnBindingLoc(mst.S_START_LOC, mst.S_CNTR_CODE.Split(',').ToList()); + } + else + { + LogHelper.Info($"浠诲姟{mst.S_CODE} 鎵樼洏涓虹┖ ,鍙В閿佽揣浣�); + LocationHelper.UnlockLoc(mst.S_START_LOC); + } } else { - Console.WriteLine($"浠诲姟{mst.S_CODE} 璐т綅{mst.S_END_LOC}鍗歌揣瀹屾垚锛岀粓鐐圭粦瀹氬鍣▄mst.S_CNTR_CODE}"); - LogHelper.Info($"浠诲姟{mst.S_CODE} 璐т綅{mst.S_END_LOC}鍗歌揣瀹屾垚锛岃捣鐐硅В缁戝鍣▄mst.S_CNTR_CODE}"); - LocationHelper.BindingLoc(mst.S_END_LOC, mst.S_CNTR_CODE.Split(',').ToList()); + // Console.WriteLine($"浠诲姟{mst.S_CODE} 璐т綅{mst.S_END_LOC}鍗歌揣瀹屾垚锛岀粓鐐圭粦瀹氬鍣▄mst.S_CNTR_CODE}"); + + if (!string.IsNullOrEmpty(mst.S_CNTR_CODE)) + { + LogHelper.Info($"浠诲姟{mst.S_CODE} 璐т綅{mst.S_END_LOC}鍗歌揣瀹屾垚锛岃捣鐐硅В缁戝鍣▄mst.S_CNTR_CODE}"); + LocationHelper.BindingLoc(mst.S_END_LOC, mst.S_CNTR_CODE.Split(',').ToList()); + } + else + { + LogHelper.Info($"浠诲姟{mst.S_CODE} 鎵樼洏涓虹┖ ,鍙В閿佽揣浣�); + LocationHelper.UnlockLoc(mst.S_END_LOC); + } } } @@ -73,15 +92,15 @@ /// <summary> /// 瀹夊叏璇锋眰 /// </summary> - /// <param name="model"></param> - /// <param name="url"></param> - /// <param name="wcs"></param> - internal static void OperateReq(AgvTaskState model, string url, WCSTask TN_Task) + /// <param name="model">璇锋眰鍙傛暟</param> + /// <param name="url">鍦板潃</param> + /// <param name="TN_Task">浠诲姟</param> + internal static void OperateReq(AgvTaskState model, string url, WCSTask TN_Task) { try { LogHelper.Info($"-------寮�瀹夊叏璇锋眰------"); - + if (TN_Task != null) { int type = 0; @@ -103,12 +122,33 @@ else { //浜曟澗鍙犵洏鏈哄畨鍏ㄤ氦浜�- if (TN_Task.Z_TYPE == 2&& TN_Task.S_NOTE=="绌烘墭鍥炲簱") + if (TN_Task.S_NOTE == "绌烘墭鍥炲簱") { - if (S7Helper.ReadDpj("DB200.DBX0.4")==1) + var Device = Settings.deviceInfos.Where(a => a.TN_Location == TN_Task.S_START_LOC).FirstOrDefault(); + if (Device != null) { - NDCApi.ChangeOrderParam(TN_Task.S_CODE.Trim(), 6, "1"); - } + if (S7Helper.WriteDpj(Device.address, 1002, 1)) + { + int value = S7Helper.ReadDpj(Device.address, 2004, S7.Net.VarType.Byte); + if (value == 1) + { + NDCApi.ChangeOrderParam(TN_Task.S_CODE.Trim(), 6, "1"); + } + else + { + LogHelper.Info("鍙犵洏鏈哄畨鍏ㄤ氦浜掑け璐ワ紝璇诲彇VB2004鐨勫�涓簕2004}"); + } + } + else + { + LogHelper.Info("鍙犵洏鏈哄畨鍏ㄤ氦浜掑け璐ワ紝鍐欏叆VB1002鍊�澶辫触"); + } + } + else + { + LogHelper.Info($"鍙犵洏鏈哄畨鍏ㄤ氦浜掑け璐ワ紝鏍规嵁浠诲姟璧风偣{TN_Task.S_START_LOC},鏈壘鍒板彔鐩樻満閰嶇疆鏂囦欢"); + } + } else { @@ -118,7 +158,7 @@ NDCApi.ChangeOrderParam(TN_Task.S_CODE.Trim(), 6, "1"); } } - + } @@ -134,9 +174,25 @@ //NDCHelper.ChangeParam(TN_Task.S_CODE.Trim(), 1101, 18); } } - if (TN_Task.Z_TYPE == 2 && TN_Task.S_NOTE == "绌烘墭鍥炲簱") + if (TN_Task.S_NOTE == "绌烘墭鍥炲簱") { - S7Helper.WriteDpj("DB100.DBX0.1",1); + var Device = Settings.deviceInfos.Where(a => a.TN_Location == TN_Task.S_START_LOC).FirstOrDefault(); + if (Device != null) + { + //鍐欏叆澶辫触閲嶆柊鍐欏叆 + while (!S7Helper.WriteDpj(Device.address, 1001, 1)) + { + Thread.Sleep(1000); + } + while (!S7Helper.WriteDpj(Device.address, 1002, 0)) + { + Thread.Sleep(1000); + } + } + else + { + LogHelper.Info($"鍙犵洏鏈哄畨鍏ㄤ氦浜掑け璐ワ紝鏍规嵁浠诲姟璧风偣{TN_Task.S_START_LOC},鏈壘鍒板彔鐩樻満閰嶇疆鏂囦欢"); + } } } if (model.state == 1103) @@ -174,7 +230,7 @@ } } } - + } catch (Exception ex) { @@ -218,6 +274,7 @@ else { LogHelper.Info($"瀹夊叏璇锋眰澶辫触=>msg:{result.msg}"); + ApiHelper.AddErrorInfo("瀹夊叏浜や簰澶辫触", result.msg, "", tasknum); } return permit; } @@ -267,6 +324,7 @@ else { LogHelper.Info($"瀹夊叏璇锋眰澶辫触=>msg:{result.err_msg}"); + ApiHelper.AddErrorInfo("瀹夊叏浜や簰澶辫触", result.err_msg, "", no); } return permit; } @@ -801,9 +859,8 @@ /// <summary> /// mes鐗╂枡鍒颁綅鍚屾 /// </summary> - /// <param name="taskNum"></param> - /// <param name="orderNum"></param> - /// <param name="taskStatus"></param> + /// <param name="mst">浠诲姟</param> + /// <param name="url">鍦板潃</param> public static void MESIteminfoback(WCSTask mst, string url) { LogHelper.Info($"------------寮�鐗╂枡淇℃伅鍥炴姤-----------"); @@ -811,37 +868,59 @@ { var cntritem = ContainerHelper.GetCntrItemRel(mst.S_CNTR_CODE).FirstOrDefault(); //鍥炴姤鏁版嵁 - Request<iteminfoArrive> statusarrive = new Request<iteminfoArrive>(); - List<LotListh> lotLists = new List<LotListh>(); - string TaskNumber = mst.S_EQ_NO; - if (!string.IsNullOrEmpty(mst.S_WMS_NO)) + Request<MesItemBackModel> request = new Request<MesItemBackModel>(); + List<MesItemBackInfoModel> list = new List<MesItemBackInfoModel>(); + string MesNo = mst.S_EQ_NO; + if (!string.IsNullOrEmpty(mst.S_MES_NO)) { - TaskNumber = mst.S_WMS_NO; + MesNo = mst.S_MES_NO; + } + //绮夋枡鍥炲簱涓嶉渶瑕佸洖鎶�+ if (cntritem != null && mst.S_TYPE == "浣欐枡杩斿洖" && cntritem.S_ITEM_CODE.StartsWith("4X")) + { + return; } //鑾峰彇鏃堕棿鎴� var time = DateTimeOffset.UtcNow.ToUnixTimeMilliseconds(); //鐗╂枡鍒颁綅鎺ュ彛鍜岀姸鎬佸弽棣堝悓鏃惰皟IIOT锛屼负浜嗗尯鍒唅d锛岀墿鏂欏埌浣嶉暱搴﹀姞涓�尯鍒�- statusarrive.RequestId = "鏉弶AGV" + time + "1"; - statusarrive.UseToken = "iFQ5fExGrLYLXliHYWzs"; + request.RequestId = "鏉弶AGV" + time + "1"; + request.UseToken = "iFQ5fExGrLYLXliHYWzs"; - iteminfoArrive iteminfoArrive = new iteminfoArrive(); - iteminfoArrive.TaskNumber = TaskNumber; - iteminfoArrive.LocationNum = mst.S_END_LOC; - iteminfoArrive.Rfid = mst.S_CNTR_CODE; - iteminfoArrive.ArricalTime = DateTime.Now.ToString("yyyy-MM-dd"); + MesItemBackModel mesItemBackModel = new MesItemBackModel(); + + mesItemBackModel.TaskNumber = MesNo; + mesItemBackModel.WmsTaskNumber = mst.S_WMS_NO; + mesItemBackModel.Rfid = mst.S_CNTR_CODE; + mesItemBackModel.LocationNum = mst.S_END_LOC; + mesItemBackModel.Result = "1"; + mesItemBackModel.ArricalTime = DateTime.Now.ToString("yyyy-MM-dd"); if (cntritem != null) { - lotLists.Add(new LotListh() { LotNumber = cntritem.S_BATCH_NO, Weight = double.Parse(cntritem.F_WEIGHT) }); - iteminfoArrive.PartDesc = cntritem.S_ITEM_NAME; - iteminfoArrive.PartNumber = cntritem.S_ITEM_CODE; + list.Add(new MesItemBackInfoModel() + { + LotNumber = cntritem.S_BATCH_NO, + PartNumber = cntritem.S_ITEM_CODE, + Subpool = cntritem.Subpool, + ReceiveLot = cntritem.ReceiveLot, + Supplier = cntritem.S_SUPPLIER_NO, + TyreType = cntritem.TyreType, + ProduceTime = cntritem.D_PRD_DATE, + Rfid = cntritem.S_CNTR_CODE, + Qty = cntritem.F_WEIGHT, + PartLevel = cntritem.LEV, + WmsLot = cntritem.WmsLot + }); + } - iteminfoArrive.LotList = lotLists; - statusarrive.data = iteminfoArrive; + + mesItemBackModel.List = list; + request.data = mesItemBackModel; + //浠诲姟涓婃姤 HttpHelper httpHelper = new HttpHelper(); MesResult result = new MesResult(); - string date = JsonConvert.SerializeObject(statusarrive); + string date = JsonConvert.SerializeObject(request); LogHelper.Info($"鐗╂枡鍒颁綅鍥炴姤锛氬湴鍧�{url}锛屽唴瀹癸細{date}"); var r = httpHelper.MesWebPost(url, date); @@ -863,6 +942,8 @@ } } + + /// <summary> /// 鍒涘缓鎼繍浠诲姟 /// </summary> -- Gitblit v1.9.1