From c6265b1f32a6c6c4e4dd478efe27d23e7d825859 Mon Sep 17 00:00:00 2001
From: huangxiaoqiang <huangxiaoqiang@hnkhzn.com>
Date: 星期三, 12 十一月 2025 16:40:25 +0800
Subject: [PATCH] 优化任务逻辑,新增API支持动态货位更新重构任务处理逻辑,支持基于区域的任务分配,优化货位状态更新,减少重复代码 更新项目路径和文档路径,反映文件结构调整。  新增 UpdateStartLocationInfo和RequestLocationAPI 方法,支持动态更新货位信息。

---
 项目代码/WCS/WIDESEAWCS_Server/WIDESEAWCS_Tasks/ConveyorLineJob/CommonConveyorLineJob.cs |   68 ++++++++++++++++++++++++----------
 1 files changed, 48 insertions(+), 20 deletions(-)

diff --git "a/\351\241\271\347\233\256\344\273\243\347\240\201/WCS/WIDESEAWCS_Server/WIDESEAWCS_Tasks/ConveyorLineJob/CommonConveyorLineJob.cs" "b/\351\241\271\347\233\256\344\273\243\347\240\201/WCS/WIDESEAWCS_Server/WIDESEAWCS_Tasks/ConveyorLineJob/CommonConveyorLineJob.cs"
index 4d5efec..10d932b 100644
--- "a/\351\241\271\347\233\256\344\273\243\347\240\201/WCS/WIDESEAWCS_Server/WIDESEAWCS_Tasks/ConveyorLineJob/CommonConveyorLineJob.cs"
+++ "b/\351\241\271\347\233\256\344\273\243\347\240\201/WCS/WIDESEAWCS_Server/WIDESEAWCS_Tasks/ConveyorLineJob/CommonConveyorLineJob.cs"
@@ -82,45 +82,73 @@
                     if (conmmand != null)
                     {
                         var structs = BitConverter.GetBytes(conmmand.InteractiveSignal).Reverse().ToArray().ToBoolArray();
-                        if (structs[2])
+                        if (structs[0] )
                         {
-                            var task = _taskRepository.QueryFirst(x => x.TaskState == (int)TaskInStatusEnum.Line_InExecuting && x.TaskNum == conmmand.ConveyorLineTargetAddress);
-                            if (task != null)
+                            var taskIn = _taskRepository.QueryFirst(x => x.TaskState == (int)TaskInStatusEnum.Line_InExecuting && x.TaskNum == conmmand.ConveyorLineTargetAddress);
+                            var taskOut = _taskRepository.QueryFirst(x => x.TaskState == (int)TaskOutStatusEnum.SC_OutFinish);
+                            var taskPut = _taskRepository.QueryFirst(x => x.TaskState == (int)TaskInStatusEnum.AGV_InFinish);
+                            if (taskPut != null)
                             {
-                                WebResponseContent content = _taskService.UpdateTaskStatusToNext(task.TaskNum);
-                                WriteInfo(conveyorLine.DeviceName, $"{JsonConvert.SerializeObject(content)}");
+                                if (conmmand.ConveyorLineTaskNum == 0)
+                                {
+                                    conveyorLine.Communicator.Write("DB100.0", Convert.ToInt32(9990));
+                                    conveyorLine.Communicator.Write("DB100.4", Convert.ToInt16(taskPut.TaskNum));
+                                    _taskService.UpdateTaskStatusToNext(taskPut.TaskNum);
+                                }
                             }
-                        }
+                            if (taskIn != null)
+                            {
+                                if (structs[2] && structs[1])
+                                {
+                                    WebResponseContent content = _taskService.UpdateTaskStatusToNext(taskIn.TaskNum);
+                                    WriteInfo(conveyorLine.DeviceName, $"{JsonConvert.SerializeObject(content)}");
+                                }
+                            }
+                            if (taskOut != null)
+                            {
+                                if (conmmand.ConveyorLineTaskNum == 0)
+                                {
+                                    if (structs[2] && structs[1])
+                                    {
+                                        conveyorLine.Communicator.Write("DB100.0", Convert.ToInt32(9999));
+                                        conveyorLine.Communicator.Write("DB100.4", Convert.ToInt16(taskOut.TaskNum));
+                                    }
+                                    WebResponseContent content = _taskService.UpdateTaskStatusToNext(taskOut.TaskNum);
+                                    if (content.Status)
+                                    {
+                                        _taskService.SendAgvTask("LKQU", taskOut.TaskNum);
+                                    }
+                                    WriteInfo(conveyorLine.DeviceName, $"{JsonConvert.SerializeObject(content)}");
+                                }
+                            }
 
-                        if (structs[0])
-                        {
-                            var task = _taskService.QueryRequestConveyorLineSignalTask();
+                            var taskSignal = _taskService.QueryRequestConveyorLineSignalTask();
 
-                            if (task != null && task.AGVSign == "RequestPickUp")
+                            if (taskSignal != null && taskSignal.AGVSign == "RequestPickUp")
                             {
                                 if (!structs[3])
                                 {
-                                    conveyorLine.Communicator.WriteNoRead("DB100.0", Convert.ToInt32(9999));
+                                    conveyorLine.Communicator.Write("DB100.0", Convert.ToInt32(9999));
                                 }
                                 if (conveyorLine.GetValue<ConveyorLineDBName, short>(ConveyorLineDBName.AllowPickUp, "LK001") == 1)
                                 {
-                                    await _taskService.ContinueAgvTask(task.AGVTaskNum);
-                                    task.AGVSign = "";
-                                    task.TaskState = (int)TaskOutStatusEnum.Line_OutFinish;
-                                    _taskRepository.UpdateData(task);
+                                    await _taskService.ContinueAgvTask(taskSignal.AGVTaskNum);
+                                    taskSignal.AGVSign = "";
+                                    taskSignal.TaskState = (int)TaskOutStatusEnum.Line_OutFinish;
+                                    _taskRepository.UpdateData(taskSignal);
                                 }
                             }
-                            if (task != null && task.AGVSign == "RequestPut")
+                            if (taskSignal != null && taskSignal.AGVSign == "RequestPut")
                             {
                                 if (!structs[3])
                                 {
-                                    conveyorLine.Communicator.WriteNoRead("DB100.0", Convert.ToInt32(9999));
+                                    conveyorLine.Communicator.Write("DB100.0", Convert.ToInt32(9999));
                                 }
                                 if (conveyorLine.GetValue<ConveyorLineDBName, short>(ConveyorLineDBName.AllowPut, "LK001") == 1)
                                 {
-                                    await _taskService.ContinueAgvTask(task.AGVTaskNum);
-                                    task.AGVSign = "";
-                                    _taskRepository.UpdateData(task);
+                                    await _taskService.ContinueAgvTask(taskSignal.AGVTaskNum);
+                                    taskSignal.AGVSign = "";
+                                    _taskRepository.UpdateData(taskSignal);
                                 }
                             }
 

--
Gitblit v1.9.3