From 733e63cb362f17aea4a1020654fa348a0d0c1f06 Mon Sep 17 00:00:00 2001
From: dengjunjie <dengjunjie@hnkhzn.com>
Date: 星期一, 24 二月 2025 00:08:59 +0800
Subject: [PATCH] 优化入库逻辑,优化直接出库逻辑,优化移库任务逻辑

---
 项目代码/WCS/WIDESEAWCS_Server/WIDESEAWCS_Tasks/ShuttleCarJob/ShuttleCarExtend/PartialTaskService.cs |   74 +++++++++++++++++++++++++++---------
 1 files changed, 55 insertions(+), 19 deletions(-)

diff --git "a/\351\241\271\347\233\256\344\273\243\347\240\201/WCS/WIDESEAWCS_Server/WIDESEAWCS_Tasks/ShuttleCarJob/ShuttleCarExtend/PartialTaskService.cs" "b/\351\241\271\347\233\256\344\273\243\347\240\201/WCS/WIDESEAWCS_Server/WIDESEAWCS_Tasks/ShuttleCarJob/ShuttleCarExtend/PartialTaskService.cs"
index ac98d73..5b728e9 100644
--- "a/\351\241\271\347\233\256\344\273\243\347\240\201/WCS/WIDESEAWCS_Server/WIDESEAWCS_Tasks/ShuttleCarJob/ShuttleCarExtend/PartialTaskService.cs"
+++ "b/\351\241\271\347\233\256\344\273\243\347\240\201/WCS/WIDESEAWCS_Server/WIDESEAWCS_Tasks/ShuttleCarJob/ShuttleCarExtend/PartialTaskService.cs"
@@ -26,22 +26,43 @@
         /// </summary>
         public void GetSC_CarFinish()
         {
-            Dt_Task dt_Task = GetTask((int)TaskCarStatusEnum.SC_CarFinish, (int)TaskOtherTypeEnum.RelocationCar);
+            Dt_Task dt_Task = GetTask((int)TaskCarStatusEnum.SC_CarFinish, (int)TaskOtherTypeEnum.RelocationCar);//绉昏溅浠诲姟
             if (dt_Task != null)
             {
-                var ShuttleCar = QueryCode(dt_Task.ShuttleCarCode);
-                ShuttleCar.ShuttleCarPosition = dt_Task.CurrentAddress;
-                string[] targetCodes = ShuttleCar.ShuttleCarPosition.Split("-");
-                
-                _shuttleCarService.UpdateData(ShuttleCar);
-                if (string.IsNullOrEmpty(dt_Task.Remark))//瀹屾垚绉诲簱浠诲姟
-                    _taskService.AddTask_Hty(dt_Task, TaskOperateTypeEnum.AutoComplete);
-                else//涓嬪彂鍏呯數浠诲姟
-                    SendTask(dt_Task);
+                UpdateShuttleCar(dt_Task.ShuttleCarCode, dt_Task.CurrentAddress);
+                _taskService.AddTask_Hty(dt_Task, TaskOperateTypeEnum.AutoComplete);
+            }
+            dt_Task = GetTask((int)CarChargingTask.SC_CarFinish, (int)TaskOtherTypeEnum.RelocationCarCharging);//绉昏溅鍏呯數浠诲姟
+            if (dt_Task != null)
+            {
+                UpdateShuttleCar(dt_Task.ShuttleCarCode, dt_Task.CurrentAddress);
+                SendTask(dt_Task);//涓嬪彂鍏呯數浠诲姟
             }
         }
         #endregion
-
+        /// <summary>
+        /// 淇敼绌挎杞︿綅缃俊鍙�
+        /// </summary>
+        /// <param name="ShuttleCarCode">绌挎杞﹀彿</param>
+        /// <param name="Address">浣嶇疆</param>
+        public void UpdateShuttleCar(string ShuttleCarCode, string Address)
+        {
+            var ShuttleCar = QueryCode(ShuttleCarCode);
+            string[] targetCodes = Address.Split("-");
+            var Row = Convert.ToInt16(targetCodes[0]);
+            if (Row == 3)
+            {
+                ShuttleCar.ShuttleCarPosition = Address;
+                ShuttleCar.ShuttleCarPosition1 = Address;
+            }
+            else
+            {
+                var a = Row == 1 ? 2.ToString("000") : 1.ToString("000");
+                ShuttleCar.ShuttleCarPosition = Address;
+                ShuttleCar.ShuttleCarPosition1 = a + "-" + targetCodes[1] + "-" + targetCodes[2];
+            }
+            _shuttleCarService.UpdateData(ShuttleCar);
+        }
         #region 鑾峰彇绉昏溅浠诲姟
         /// <summary>
         /// 鑾峰彇绉昏溅浠诲姟/鍑哄叆搴撲换鍔�
@@ -60,7 +81,7 @@
                             UpdateSource(ref dt_Task, shuttleCar);
                         }
                         else
-                        {
+                        {//闇�浼樺寲
                             #region 鍒ゆ柇鏄惁瀛樺湪绌洪棽绌挎杞�,濡傞兘鍦ㄥ厖鐢�(閫夋嫨鐢甸噺楂樼殑骞惰秴杩�50%鐢甸噺鐨勭┛姊溅閫�鍑哄厖鐢�)
                             QuitCharging(dt_Task, shuttleCar, command);
                             #endregion
@@ -84,7 +105,7 @@
                         }
                         #endregion
                     }
-                    //绌挎杞︾Щ搴撲换鍔′笅鍙�
+                    //绌挎杞︾Щ杞︿换鍔′笅鍙�
                     if (!string.IsNullOrEmpty(dt_Task.SourceAddress) && !string.IsNullOrEmpty(dt_Task.TargetAddress) && !string.IsNullOrEmpty(dt_Task.ShuttleCarCode))
                     {
                         SendTask(dt_Task);
@@ -93,15 +114,24 @@
                 #region 绌挎杞﹀嚭鍏ュ簱浠诲姟
                 else
                 {
+                    var task1 = _taskService.ShuttleCarRelocationTask(shuttleCar.DeviceCode);//鑾峰彇绌挎杞︾Щ搴撲换鍔�
                     var task = _taskService.QueryShuttleCarTask(shuttleCar.DeviceCode);
                     if (task != null)
                     {
-                        if (task.TaskType == (int)TaskOutboundTypeEnum.Outbound && !task.IsPickPlace)
+                        if (task.TaskType == (int)TaskRelocationTypeEnum.Relocation && task.TaskState == (int)TaskRelocationStatusEnum.RelocationNew && !task.SourceIsPickPlace)//绉诲簱浠诲姟鍒ゆ柇璧风偣鏄惁鏈夌┛姊溅
                         {
-                            var ShuttleCar = _shuttleCarService.QueryShuttleCar(task.SourceAddress);//鍑哄簱浠诲姟鍒ゆ柇鏄惁瀛樺湪绌挎杞�
+                            var ShuttleCar = _shuttleCarService.QueryShuttleCar(task.SourceAddress);
                             if (ShuttleCar != null) SendTask(task);
                             else _taskService.AddRelocationCarTask("", task.SourceAddress);
                         }
+                        else if (task.TaskType == (int)TaskOutboundTypeEnum.Outbound && !task.SourceIsPickPlace)
+                        {
+                            var ShuttleCar = _shuttleCarService.QueryShuttleCar(task.SourceAddress);//鍑哄簱浠诲姟鍒ゆ柇璧风偣鏄惁鏈夌┛姊溅
+                            if (ShuttleCar != null) SendTask(task);
+                            else _taskService.AddRelocationCarTask("", task.SourceAddress);
+                        }
+                        else
+                            SendTask(task);
                     }
                 }
                 #endregion
@@ -178,16 +208,21 @@
                 if (command != null && command.Status == (short)ShuttleCarStatus.Standby && command.TaskTypeComplete == (short)ShuttleCarTaskComplete.Standby && command.Err_Status == (short)ShuttleCarErr.Normal)
                 {
                     #region 鍒ゆ柇灏忚溅浣嶇疆鏃燗B闈笉涓嬪彂浠诲姟
-                    if (command.Position != 1 && command.Position != 2)
+                    short Position = 0;
+                    if (shuttleCar.GetValue<ShuttleCarDBName, bool>(ShuttleCarDBName.DirectionA)) Position = 1;
+                    if (shuttleCar.GetValue<ShuttleCarDBName, bool>(ShuttleCarDBName.DirectionB)) Position = 2;
+                    if (Position != 1 && Position != 2)
                     {
-                        task.ExceptionMessage = $"{shuttleCar.DeviceName}灏忚溅浣嶇疆寮傚父";
-                        _taskService.UpdateData(task);
+                        var Message = $"{shuttleCar.DeviceName}鏃燗B闈�";
+                        if (task.ExceptionMessage != Message)
+                            _taskService.UpdateData(task);
                         return;
                     }
                     #endregion
                     //浠诲姟杞崲
+                    shuttleCar.SetValue(ShuttleCarDBName.Direction, Position);//鍐欏叆杞︿綋鏂瑰悜
                     ShuttleCarTaskCommandW shuttleCarTaskCommand = new ShuttleCarTaskCommandW();
-                    shuttleCarTaskCommand.Direction = command.Position;
+                    shuttleCarTaskCommand.Direction = Position;
                     shuttleCarTaskCommand.TaskNum = task.TaskNum;
                     if (task.TaskType == (int)TaskOtherTypeEnum.RelocationCar)//绉昏溅
                     {
@@ -261,6 +296,7 @@
                     taskType = ShuttleCarTaskType.Out;
                     break;
                 case (int)TaskOtherTypeEnum.RelocationCar:
+                case (int)TaskOtherTypeEnum.RelocationCarCharging:
                     taskType = Direction == 1 ? ShuttleCarTaskType.ZeroA : ShuttleCarTaskType.ZeroB;
                     break;
                 default:

--
Gitblit v1.9.3