From 5321419f5fddb4e877fe90ccd90ebdc1a115af64 Mon Sep 17 00:00:00 2001
From: 海波 张 <2956280567@qq.com>
Date: 星期五, 18 七月 2025 17:29:26 +0800
Subject: [PATCH] 出库修改

---
 core/Monitor.cs |   78 ++++++++++++++++++++++++--------------
 1 files changed, 49 insertions(+), 29 deletions(-)

diff --git a/core/Monitor.cs b/core/Monitor.cs
index b46a4a7..fb5cd58 100644
--- a/core/Monitor.cs
+++ b/core/Monitor.cs
@@ -23,6 +23,8 @@
     /// </summary>
     internal class Monitor
     {
+        private static object CreateTaskLocker = new object();
+
         /// <summary>
         /// 鏍规嵁浣滀笟鍒涘缓瀵瑰簲浠诲姟
         /// </summary>
@@ -30,12 +32,18 @@
         {
             var db = new SqlHelper<object>().GetInstance();
 
-            // 鑾峰彇鎵�湁绛夊緟涓殑浣滀笟
-            var operations = db.Queryable<WmsWork>().Where(p => p.N_B_STATE == 0).ToList();
-            foreach (var operation in operations)
+            lock (CreateTaskLocker)
             {
-                TaskHelper.CreateTask(operation);
+                // 鑾峰彇鎵�湁绛夊緟涓殑浣滀笟
+                var operations = db.Queryable<WmsWork>().Where(p => p.N_B_STATE == 0).ToList();
+
+                foreach (var operation in operations)
+                {
+                    TaskHelper.CreateTask(operation);
+                }
             }
+
+            
         }
 
 
@@ -157,7 +165,6 @@
                                         TaskHelper.Begin(wmsTask, model.forklift_no);
                                         //鑳庨潰浜や簰
                                         TaskHelper.TmSafety(wmsTask);
-                                        TaskHelper.opMesTask(wmsTask,1);
                                         break;
                                     case 3:
                                         TaskHelper.UpdateStatus(wmsTask, "寮�鍙栬揣");
@@ -166,6 +173,7 @@
                                         TaskHelper.UpdateStatus(wmsTask, "鍙栬揣瀹屾垚");
                                         LocationHelper.UnLockLoc(wmsTask.S_START_LOC);
                                         TaskProcess.OperateStatus(wmsTask, 4);
+                                        TaskHelper.opMesTask(wmsTask, 1);
                                         break;
                                     case 5:
                                         TaskHelper.UpdateStatus(wmsTask, "寮�鍗歌揣");
@@ -189,16 +197,23 @@
                                         LogHelper.Info($"浠诲姟{wmsTask.S_CODE}瀹屾垚锛屽垽鏂叆搴撲紭鍏堢骇", "鍏ュ簱浼樺厛绾�);
                                         TaskProcess.inPri(wmsTask);
                                         TaskHelper.End(wmsTask);
-                                        TaskHelper.opMesTask(wmsTask, 2);
+                                       
                                         break;
                                     case 7:
-                                            var wcsTask1 = TaskHelper.GetTaskByWorkNo(wmsTask.S_OP_CODE, "wcs");
+                                        if (!LocationHelper.GetErroArea(wmsTask.S_END_AREA)) {
+                                            TaskHelper.opMesTask(wmsTask, 3);
+                                        }
+                                            
+                                        var wcsTask1 = TaskHelper.GetTaskByWorkNo(wmsTask.S_OP_CODE, "wcs");
                                             if (wcsTask1 != null)
                                             {
                                                 //agv鎵ц閫氱煡 wcs鍙栨秷  
                                                 WcsTask.WcsCallback(wmsTask, model.state, model.forklift_no.ToString());
-                                                TaskHelper.Fail(wcsTask1);
-                                                TaskProcess.OperateStatus(wcsTask1, 7);
+                                                if (wcsTask1.S_B_STATE.Trim() != "鍙栨秷" && wcsTask1.S_B_STATE.Trim() != "澶辫触" && wcsTask1.S_B_STATE.Trim() != "瀹屾垚")
+                                                {
+                                                    TaskHelper.Fail(wcsTask1);
+                                                    TaskProcess.OperateStatus(wcsTask1, 7);
+                                                }
                                             }
                                         
 
@@ -209,17 +224,21 @@
                                         {
                                             ContainerHelper.delCntr(wmsTask.S_CNTR_CODE);
                                             ContainerHelper.delCntrItem(wmsTask.S_CNTR_CODE);
+                                            ContainerHelper.delCntrLoc(wmsTask.S_CNTR_CODE);
                                         }
-
-                                        //鍑哄簱鍙栨秷鍒ゆ柇鎺ラ┏浣嶆槸鍚︽湁璐э紝鏈夎揣闇�瑙g粦
-                                        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);
+                                        else {
+                                            //鍑哄簱鍙栨秷鍒ゆ柇鎺ラ┏浣嶆槸鍚︽湁璐э紝鏈夎揣闇�瑙g粦
+                                            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);
+                                            }
                                         }
-                                        TaskHelper.opMesTask(wmsTask, 3);
+                                        
+                                      
+                                       
                                         break;
 
                                 }
@@ -331,7 +350,7 @@
 
 
                         //瀵绘壘绔嬪簱鍖虹┖鎵�-                        start = LocationHelper.FindStartcolByLoclistAndcntr(strrtList, workFlow.STARTAREA);
+                        start = LocationHelper.FindStartcolByLoclistAndcntr(strrtList, workFlow.STARTAREA,workFlow.CONNECTION);
 
 
                         LogHelper.Info($"绌烘墭{kt.task_no}鍑哄簱浠诲姟涓嬪彂璧风偣淇℃伅" + JsonConvert.SerializeObject(start), "绌烘墭鍑哄簱");
@@ -353,22 +372,20 @@
                         var cntrCode = LocationHelper.GetLocCntrCode(start.S_CODE);
 
                         if (workFlow.SENDWCS == "Y")
-                        {   
-                            //姝e紡浠g爜锛岃皟鐢ㄦ帴鍙e鎵惧彲鐢ㄦ帴椹充綅
+                        {     
                             var connectionList = LocationHelper.GetConnectionList(workFlow.CONNECTION);
-
+                            //鏍规嵁鎺ラ┏浣嶄换鍔℃暟閲忚幏鍙栧潎琛℃帴椹充綅闆嗗悎浼樺厛浠诲姟鏁板皯鐨勬帴椹充綅
                             var balanceConnectionList = LocationHelper.GetBalanceConnectionList(connectionList);
                             foreach (var item in balanceConnectionList)
                             {
-                                if (item.loc.N_CURRENT_NUM < 2 && item.loc.CONNEC_ROADWAY == start.N_ROADWAY)
+                                if (item.loc.CONNEC_ROADWAY == start.N_ROADWAY)
                                 {
                                     connection = item.loc.S_CODE;
                                     connectionArea = item.loc.S_AREA_Name;
-                                    LogHelper.Info($"绌烘墭{kt.task_no}鍑哄簱浠诲姟涓嬪彂瀵绘壘鍒板彲鐢ㄦ帴椹充綅{connection}", "绌烘墭鍑哄簱");
+                                    LogHelper.Info($"ZCSendTask鍑哄簱浠诲姟涓嬪彂瀵绘壘鍒板彲鐢ㄦ帴椹充綅{connection}", "Mes浠诲姟涓嬪彂");
                                     break;
                                 }
                             }
-
                             if (connection == "")
                             {
                                 LogHelper.Info($"绌烘墭{kt.task_no}鍑哄簱浠诲姟涓嬪彂瀵绘壘鎺ラ┏浣嶅け璐�, "Mes浠荤┖鎵樺嚭搴撳姟涓嬪彂");
@@ -384,9 +401,6 @@
                             continue;
                         }
 
-
-
-                        LocationHelper.LockLoc(start.S_CODE, "鍑哄簱閿�, 2);
                       
 
 
@@ -428,10 +442,16 @@
                             CONNECTION_AREA = connectionArea
                         };
 
+
                         //鍒涘缓浣滀笟
                         if (WMSHelper.CreateWmsWork(operation) && TaskHelper.ChangeMesKtTask(kt))
                         {
-
+                            if (connection != "")
+                            {
+                                LocationHelper.LockLoc(operation.S_START_LOC, "鍑哄簱閿�, 2);
+                                LocationHelper.LockLoc(operation.S_END_LOC, "鍏ュ簱閿�, 1);
+                                LocationHelper.LockLoc(operation.CONNECTION, "鍏ュ簱閿�, 1);
+                            }
                             LogHelper.Info($"绌烘墭{kt.task_no}鍑哄簱浣滀笟鍒涘缓鎴愬姛{operation.S_CODE}", "绌烘墭鍑哄簱");
                         }
                         else

--
Gitblit v1.9.1