From b7da1f32d5d9997378b5ac535593a3f6144af46b Mon Sep 17 00:00:00 2001
From: huangxiaoqiang <huangxiaoqiang@hnkhzn.com>
Date: 星期三, 15 十月 2025 17:15:38 +0800
Subject: [PATCH] 新增AGV与堆垛机移库判断及缓存优化

---
 项目代码/WCS/WIDESEAWCS_Server/WIDESEAWCS_Tasks/AGV/CommonAGVJob.cs |  128 +++++++++++++++++++++++++++++++++++++-----
 1 files changed, 111 insertions(+), 17 deletions(-)

diff --git "a/\351\241\271\347\233\256\344\273\243\347\240\201/WCS/WIDESEAWCS_Server/WIDESEAWCS_Tasks/AGV/CommonAGVJob.cs" "b/\351\241\271\347\233\256\344\273\243\347\240\201/WCS/WIDESEAWCS_Server/WIDESEAWCS_Tasks/AGV/CommonAGVJob.cs"
index ffde2f2..853bb61 100644
--- "a/\351\241\271\347\233\256\344\273\243\347\240\201/WCS/WIDESEAWCS_Server/WIDESEAWCS_Tasks/AGV/CommonAGVJob.cs"
+++ "b/\351\241\271\347\233\256\344\273\243\347\240\201/WCS/WIDESEAWCS_Server/WIDESEAWCS_Tasks/AGV/CommonAGVJob.cs"
@@ -1,4 +1,6 @@
 锘縰sing HslCommunication;
+using Newtonsoft.Json;
+using Newtonsoft.Json.Linq;
 using Quartz;
 using System;
 using System.Collections.Generic;
@@ -6,9 +8,16 @@
 using System.Linq;
 using System.Text;
 using System.Threading.Tasks;
+using WIDESEAWCS_Common;
 using WIDESEAWCS_Common.TaskEnum;
+using WIDESEAWCS_Core;
+using WIDESEAWCS_Core.Helper;
+using WIDESEAWCS_DTO.TaskInfo;
+using WIDESEAWCS_DTO.WMS;
+using WIDESEAWCS_ISystemServices;
 using WIDESEAWCS_ITaskInfoRepository;
 using WIDESEAWCS_ITaskInfoService;
+using WIDESEAWCS_Model.Models;
 using WIDESEAWCS_QuartzJob;
 using WIDESEAWCS_Tasks.ConveyorLineJob;
 using WIDESEAWCS_Tasks.ElevatorJob;
@@ -20,10 +29,12 @@
     {
         private readonly ITaskRepository _taskRepository;
         private readonly ITaskService _taskService;
-        public CommonAGVJob(ITaskRepository taskRepository,ITaskService taskService) 
+        private readonly ISys_ConfigService _sys_ConfigService;
+        public CommonAGVJob(ITaskRepository taskRepository,ITaskService taskService,ISys_ConfigService configService) 
         {
             _taskRepository = taskRepository;
             _taskService = taskService;
+            _sys_ConfigService = configService;
         }
 
         public Task Execute(IJobExecutionContext context)
@@ -71,29 +82,91 @@
             #endregion
 
             #region AGV鍚屽眰鎼繍浠诲姟
+
+            var CarryTask = _taskRepository.QueryData(x => x.TaskType == (int)TaskAGVCarryTypeEnum.CarryReloction && x.TaskState == (int)TaskAGVCarryStatusEnum.CarryNew);
             var Carry = _taskRepository.QueryFirst(x => x.TaskState == (int)TaskAGVCarryStatusEnum.CarryNew);
+            if (CarryTask .Count>0)
+            {
+                foreach (var item in CarryTask)
+                {
+                    AGVSendTask(item);
+                }
+            }
 
             if (Carry != null)
             {
-                if (Carry.SourceAddress.Contains("XB001") || Carry.TargetAddress.Contains("XB001"))
+                var task = _taskRepository.QueryFirst(x => x.TaskState > (int)TaskAGVCarryStatusEnum.CarryNew);
+                if (task == null)
                 {
-                    _taskService.SendAgvTask("cattleCarry1", Carry.TaskNum);
-                    Carry.TaskState = (int)TaskAGVCarryStatusEnum.AGV_CarryExecuting;
-                    _taskRepository.UpdateData(Carry);
-                }
-                else if (Carry.Floor == "1F")
-                {
-                    _taskService.SendAgvTask("forkAutoTemplate1", Carry.TaskNum);
-                    Carry.TaskState = (int)TaskAGVCarryStatusEnum.AGV_CarryExecuting;
-                    _taskRepository.UpdateData(Carry);
-                }
-                else
-                {
-                    _taskService.SendAgvTask("cattleCarry1", Carry.TaskNum);
-                    Carry.TaskState = (int)TaskAGVCarryStatusEnum.AGV_CarryExecuting;
-                    _taskRepository.UpdateData(Carry);
+                    var taskDto = new RequestTaskDto()
+                    {
+                        Position = Carry.SourceAddress,
+                        PalletCode = Carry.PalletCode,
+                        TaskNum = Carry.TaskNum
+                    };
+
+                    // 鑾峰彇WMSip鍦板潃
+                    var configz = _sys_ConfigService.GetConfigsByCategory(CateGoryConst.CONFIG_SYS_IPAddress);
+                    var wmsBasez = configz.Where(x => x.ConfigKey == SysConfigKeyConst.WMSIP_BASE).FirstOrDefault()?.ConfigValue;
+                    var requestLocation = configz.Where(x => x.ConfigKey == SysConfigKeyConst.AGVIsNeedRelocation).FirstOrDefault()?.ConfigValue;
+                    if (wmsBasez == null || requestLocation == null)
+                    {
+                        throw new InvalidOperationException("WMS IP 鏈厤缃�");
+                    }
+                    var wmsIpAddrss = wmsBasez + requestLocation;
+
+                    var result = HttpHelper.PostAsync(wmsIpAddrss, taskDto.ToJsonString()).Result;
+
+                    WebResponseContent content = JsonConvert.DeserializeObject<WebResponseContent>(result);
+
+                    if (!content.Status)
+                    {
+                        Carry.ExceptionMessage = content.Message;
+                        _taskRepository.UpdateData(Carry);
+                        return null;
+                    }
+
+                    // 鍙嶅簭鍒楀寲浠诲姟鏁版嵁
+                    var taskDTO = JsonConvert.DeserializeObject<List<WMSTaskDTO>>(content.Data.ToString());
+                    bool IsAddTask = false;
+                    foreach (var t in taskDTO)
+                    {
+                        if (t.TaskNum == Carry.TaskNum)
+                        {
+                            IsAddTask = true;
+                            break;
+                        }
+                        else
+                        {
+                            IsAddTask = true;
+                        }
+                    }
+                    if (IsAddTask)
+                        _taskService.ReceiveWMSTask(taskDTO);
+
+                    var taskNew = _taskRepository.QueryData(x => x.TaskType == (int)TaskAGVCarryTypeEnum.CarryReloction && x.TaskState == (int)TaskAGVCarryStatusEnum.CarryNew);
+                    if (taskNew.Count > 0)
+                    {
+                        if (taskNew[0].Remark == "2")
+                        {
+                            foreach (var item in taskNew.OrderBy(x => x.Grade).ToList())
+                            {
+                                AGVSendTask(item);
+                            }
+                        }
+                        else
+                        {
+                            foreach (var item in taskNew.OrderByDescending(x => x.Grade).ToList())
+                            {
+                                AGVSendTask(item);
+                            }
+                        }
+                    }
+
+                    AGVSendTask(Carry);
                 }
             }
+
             #endregion
 
             #region 1妤糀GV鍏ュ簱浠诲姟
@@ -132,5 +205,26 @@
 
             return Task.CompletedTask;
         }
+        public void AGVSendTask(Dt_Task task)
+        {
+            if (task.SourceAddress.Contains("XB001") || task.TargetAddress.Contains("XB001"))
+            {
+                _taskService.SendAgvTask("cattleCarry1", task.TaskNum);
+                task.TaskState = (int)TaskAGVCarryStatusEnum.AGV_CarryExecuting;
+                _taskRepository.UpdateData(task);
+            }
+            else if (task.Floor == "1F")
+            {
+                _taskService.SendAgvTask("forkAutoTemplate1", task.TaskNum);
+                task.TaskState = (int)TaskAGVCarryStatusEnum.AGV_CarryExecuting;
+                _taskRepository.UpdateData(task);
+            }
+            else
+            {
+                _taskService.SendAgvTask("cattleCarry1", task.TaskNum);
+                task.TaskState = (int)TaskAGVCarryStatusEnum.AGV_CarryExecuting;
+                _taskRepository.UpdateData(task);
+            }
+        }
     }
 }

--
Gitblit v1.9.3