From 61ece19b5b178d1b23bed16c733b01af1185f838 Mon Sep 17 00:00:00 2001 From: 海波 张 <2956280567@qq.com> Date: 星期日, 20 七月 2025 23:11:43 +0800 Subject: [PATCH] 0720 --- core/Monitor.cs | 79 +++++++++++++++++++++++++++++++-------- 1 files changed, 62 insertions(+), 17 deletions(-) diff --git a/core/Monitor.cs b/core/Monitor.cs index fb5cd58..620b137 100644 --- a/core/Monitor.cs +++ b/core/Monitor.cs @@ -14,6 +14,7 @@ using System.Threading; using System.Threading.Tasks; using System.Web.Services.Description; +using Top.Api; using static HH.WCS.ZhongCeJinTan.api.ApiModel; namespace HH.WCS.ZhongCeJinTan.core @@ -197,28 +198,59 @@ LogHelper.Info($"浠诲姟{wmsTask.S_CODE}瀹屾垚锛屽垽鏂叆搴撲紭鍏堢骇", "鍏ュ簱浼樺厛绾�); TaskProcess.inPri(wmsTask); TaskHelper.End(wmsTask); - break; case 7: if (!LocationHelper.GetErroArea(wmsTask.S_END_AREA)) { TaskHelper.opMesTask(wmsTask, 3); } + TaskHelper.Fail(wmsTask); + TaskProcess.OperateStatus(wmsTask, 7); + + + WmsTaskAction ac4 = TaskHelper.GetActionRecord(wmsTask.S_CODE, "4"); + //宸茬粡鍙栬揣瀹屾垚 + if (ac4 != null) + { - var wcsTask1 = TaskHelper.GetTaskByWorkNo(wmsTask.S_OP_CODE, "wcs"); + } + + var wcsTask1 = TaskHelper.GetTaskByWorkNo(wmsTask.S_OP_CODE, "wcs"); if (wcsTask1 != null) { - //agv鎵ц閫氱煡 wcs鍙栨秷 - WcsTask.WcsCallback(wmsTask, model.state, model.forklift_no.ToString()); if (wcsTask1.S_B_STATE.Trim() != "鍙栨秷" && wcsTask1.S_B_STATE.Trim() != "澶辫触" && wcsTask1.S_B_STATE.Trim() != "瀹屾垚") { TaskHelper.Fail(wcsTask1); TaskProcess.OperateStatus(wcsTask1, 7); - } + if (wmsTask.S_TYPE.Contains("鍑哄簱")) + { + WmsTaskAction ac1101 = TaskHelper.GetActionRecord(wmsTask.S_CODE, "1101"); + WmsTaskAction ac1102 = TaskHelper.GetActionRecord(wmsTask.S_CODE, "1102"); + if ((ac1101 != null)) + { + if (ac1102 == null) + { + //agv鎵ц閫氱煡 wcs鍙栨秷 + WcsTask.WcsCallback(wmsTask, model.state, model.forklift_no.ToString()); + } + } + } + else + { + WmsTaskAction ac1103 = TaskHelper.GetActionRecord(wmsTask.S_CODE, "1103"); + WmsTaskAction ac1104 = TaskHelper.GetActionRecord(wmsTask.S_CODE, "1104"); + if ((ac1103 != null)) + { + if (ac1104 == null) + { + //agv鎵ц閫氱煡 wcs鍙栨秷 + WcsTask.WcsCallback(wmsTask, model.state, model.forklift_no.ToString()); + } + } + } + } } - - TaskHelper.Fail(wmsTask); - TaskProcess.OperateStatus(wmsTask, 7); + //鍏ュ簱鎴栬�鍥炲簱浠诲姟鍙栨秷鍒犻櫎鎵樼洏鐗╂枡 if (wmsTask.S_TYPE.Contains("鍏ュ簱") || wmsTask.S_TYPE.Contains("鍥炲簱")) { @@ -228,19 +260,32 @@ } else { //鍑哄簱鍙栨秷鍒ゆ柇鎺ラ┏浣嶆槸鍚︽湁璐э紝鏈夎揣闇�瑙g粦 - if (!WcsTask.WcsCvstate(wmsTask)) + var wmsWork = TaskHelper.GetWmsWork(wmsTask.S_OP_CODE); + if (wmsWork != null) { - LogHelper.Info($"Wcs绔嬪簱鎺ラ┏浣嶆棤璐э紝瑙g粦璐т綅:{wmsTask.S_START_LOC}", "绔嬪簱"); - TaskProcess.OperateStatus(wmsTask, 4); - ContainerHelper.delCntr(wmsTask.S_CNTR_CODE); - ContainerHelper.delCntrItem(wmsTask.S_CNTR_CODE); + if (!string.IsNullOrEmpty(wmsWork.CONNECTION)) + { + var agvTask = LocationHelper.GetConnectionTask(wmsWork.CONNECTION, "agv",wmsTask.T_CREATE); + LogHelper.Info($"鍙栨秷浠诲姟{wmsTask.S_CODE}锛屽綋鍓嶆帴椹充綅{wmsWork.CONNECTION}锛岀涓�釜agv浠诲姟淇℃伅" + JsonConvert.SerializeObject(agvTask), "agv鍔ㄤ綔缂撳瓨"); + if (agvTask != null) + { + WmsTaskAction qh = TaskHelper.GetActionRecord(agvTask.S_CODE, "4"); + //宸茬粡鍙栬揣瀹屾垚 + if (qh != null) + { + if (!WcsTask.WcsCvstate(wmsTask)) + { + LogHelper.Info($"Wcs绔嬪簱鎺ラ┏浣嶆棤璐э紝瑙g粦璐т綅:{wmsTask.S_START_LOC}", "绔嬪簱"); + TaskProcess.OperateStatus(wmsTask, 4); + ContainerHelper.delCntr(wmsTask.S_CNTR_CODE); + ContainerHelper.delCntrItem(wmsTask.S_CNTR_CODE); + } + } + } + } } } - - - break; - } TaskHelper.AddActionRecord(wmsTask.S_CODE, model.state, model.forklift_no, model.ext_data); } -- Gitblit v1.9.1