From 970d9c5c36d526a587138232ae9dae719dbcd16d Mon Sep 17 00:00:00 2001
From: dengjunjie <dengjunjie@hnkhzn.com>
Date: 星期一, 14 四月 2025 16:43:16 +0800
Subject: [PATCH] WCS添加获取设备信息

---
 项目代码/WCS/WIDESEAWCS_Server/WIDESEAWCS_Tasks/ShuttleCarJob/ShuttleCarExtend/PartialTaskService.cs |   49 ++++++++++++++++++++++++++++++++++++-------------
 1 files changed, 36 insertions(+), 13 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 6d553fa..0b9005d 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"
@@ -74,9 +74,20 @@
         {
             lock (_CarTaskObject)
             {
+                #region 鑾峰彇鏂板缓绉昏溅鍏呯數浠诲姟
+                Dt_Task dt_Task = GetTask((int)CarChargingTaskEnum.CarNew, (int)TaskOtherTypeEnum.RelocationCarCharging);
+                if (dt_Task != null && dt_Task.ShuttleCarCode == shuttleCar.DeviceCode)
+                {
+                    if (!string.IsNullOrEmpty(dt_Task.SourceAddress) && !string.IsNullOrEmpty(dt_Task.TargetAddress) && !string.IsNullOrEmpty(dt_Task.ShuttleCarCode))
+                    {
+                        SendTask(dt_Task);
+                    }
+                }
+                #endregion
+
                 #region 鑾峰彇鏂板缓绉昏溅浠诲姟
-                Dt_Task dt_Task = GetTask((int)TaskCarStatusEnum.CarNew, (int)TaskOtherTypeEnum.RelocationCar);
-                if (dt_Task != null)
+                dt_Task = GetTask((int)TaskCarStatusEnum.CarNew, (int)TaskOtherTypeEnum.RelocationCar);
+                if (dt_Task != null && dt_Task.ShuttleCarCode == shuttleCar.DeviceCode)
                 {
                     if (string.IsNullOrEmpty(dt_Task.SourceAddress))
                     {
@@ -89,8 +100,9 @@
                     else if (string.IsNullOrEmpty(dt_Task.TargetAddress))
                     {
                         #region 鍚慦MS鐢宠
+                        var ShuttleCar = _shuttleCarService.QueryNoCode(dt_Task.ShuttleCarCode);
                         WebResponseContent content = new WebResponseContent();
-                        var ResultData = HttpHelper.PostAsync(WMSInterfaceAddress.GetPosition + $"?position={dt_Task.SourceAddress}", "", headers: new Dictionary<string, string>());
+                        var ResultData = HttpHelper.PostAsync(WMSInterfaceAddress.GetPosition + $"?position={dt_Task.SourceAddress}&&position1={ShuttleCar.ShuttleCarPosition}", "", headers: new Dictionary<string, string>());
                         if (ResultData.Result != null)
                         {
                             content = JsonConvert.DeserializeObject<WebResponseContent>(ResultData.Result);
@@ -126,11 +138,15 @@
                         task = _taskService.QueryShuttleCarTask(shuttleCar.DeviceCode);
                         if (task != null)
                         {
-                            if (task.TaskType == (int)TaskOutboundTypeEnum.Outbound && !task.SourceIsPickPlace)
+                            if (_taskService.TaskOutboundTypes.Contains(task.TaskType) && !task.SourceIsPickPlace)
                             {
                                 var ShuttleCar = _shuttleCarService.QueryShuttleCar(task.SourceAddress);//鍑哄簱浠诲姟鍒ゆ柇璧风偣鏄惁鏈夌┛姊溅
-                                if (ShuttleCar != null) SendTask(task);
-                                else _taskService.AddRelocationCarTask("", task.SourceAddress);
+                                if (ShuttleCar == null) _taskService.AddRelocationCarTask("", task.SourceAddress);
+                                else
+                                {
+                                    task.ShuttleCarCode = ShuttleCar.ShuttleCarCode;
+                                    SendTask(task);
+                                }
                             }
                             else
                                 SendTask(task);
@@ -212,7 +228,7 @@
             if (shuttleCar != null)
             {
                 ShuttleCarTaskCommandR command = ReadCustomer<ShuttleCarTaskCommandR>(shuttleCar, shuttleCar.DeviceCode);//璇诲彇绌挎杞︿俊鎭�
-                if (command != null && command.Status == (short)ShuttleCarStatus.Standby && command.TaskTypeComplete == (short)ShuttleCarTaskComplete.Standby && command.Err_Status == (short)ShuttleCarErr.Normal)
+                if (command != null && command.Status == (short)ShuttleCarStatus.Standby && command.TaskTypeComplete == (short)ShuttleCarTaskComplete.Standby && (command.Err_Status == (short)ShuttleCarErr.Normal || command.Err_Status == (short)ShuttleCarErr.LowBattery))
                 {
                     #region 鍒ゆ柇灏忚溅浣嶇疆鏃燗B闈笉涓嬪彂浠诲姟
                     short Position = 0;
@@ -222,7 +238,10 @@
                     {
                         var Message = $"{shuttleCar.DeviceName}鏃燗B闈�";
                         if (task.ExceptionMessage != Message)
+                        {
+                            task.ExceptionMessage = Message;
                             _taskService.UpdateData(task);
+                        }
                         return;
                     }
                     #endregion
@@ -248,7 +267,9 @@
                     }
                     else if (task.TaskType == (int)TaskOtherTypeEnum.RelocationCarCharging)
                     {
-                        shuttleCarTaskCommand.TaskType = (short)GetCarTaskType(ShuttleCarTaskType.Charging.ToString());
+                        shuttleCarTaskCommand.TaskType = task.TaskState == CarChargingTaskEnum.CarNew.ObjToInt() ?
+                            (short)GetCarTaskType(task.TaskType, shuttleCarTaskCommand.Direction) :
+                            (short)GetCarTaskType(ShuttleCarTaskType.Charging.ToString());
                     }
                     else
                         shuttleCarTaskCommand.TaskType = (short)GetCarTaskType(task.TaskType, shuttleCarTaskCommand.Direction);
@@ -258,8 +279,9 @@
                     {
                         if (shuttleCar.SendCommand(shuttleCarTaskCommand, shuttleCar.DeviceCode))
                         {
-                            if (!string.IsNullOrEmpty(task.Remark)) task.Remark = task.Remark + "宸蹭笅鍙�";
-                            task.TaskState = GetTaskState(task.TaskType);
+                            if (!string.IsNullOrEmpty(task.Remark) && task.TaskState == CarChargingTaskEnum.CarNew.ObjToInt())
+                                task.Remark = task.Remark + "宸蹭笅鍙�";
+                            task.TaskState = GetTaskState(task.TaskType, task.TaskState);
                             _taskService.UpdateData(task);
                         }
                     }
@@ -320,9 +342,8 @@
         /// </summary>
         /// <param name="TaskType"></param>
         /// <returns></returns>
-        int GetTaskState(int TaskType)
+        int GetTaskState(int TaskType, int state)
         {
-            int state = 0;
             switch (TaskType)
             {
                 case (int)TaskInboundTypeEnum.Inbound:
@@ -337,7 +358,9 @@
                     state = (int)TaskCarStatusEnum.ShuttleCar_Executing;
                     break;
                 case (int)TaskOtherTypeEnum.RelocationCarCharging:
-                    state = (int)CarChargingTaskEnum.ShuttleCar_Charging;
+                    state = state < (int)CarChargingTaskEnum.SC_CarFinish ?
+                        (int)CarChargingTaskEnum.ShuttleCar_Executing :
+                        (int)CarChargingTaskEnum.ShuttleCar_Charging;
                     break;
                 default:
                     break;

--
Gitblit v1.9.3