1
z8018
2025-06-10 e46aa927d231af83724683c7286d9db503e24cf7
ÏîÄ¿´úÂë/WCS/WIDESEAWCS_Server/WIDESEAWCS_Tasks/Gantry/GantryJob.cs
@@ -3,99 +3,531 @@
using System.Linq;
using System.Text;
using System.Threading.Tasks;
using HslCommunication.WebSocket;
using Quartz;
using WIDESEAWCS_Common;
using WIDESEAWCS_Core.Helper;
using WIDESEAWCS_IBasicInfoRepository;
using WIDESEAWCS_IBasicInfoService;
using WIDESEAWCS_ITaskInfoRepository;
using WIDESEAWCS_ITaskInfoService;
using WIDESEAWCS_Model.Models;
using WIDESEAWCS_QuartzJob;
using WIDESEAWCS_QuartzJob.DTO;
namespace WIDESEAWCS_Tasks
{
    /// <summary>
    /// é¾™é—¨æž¶
    /// é¾™é—¨æž¶ä»»åŠ¡å¤„ç†ç±»ï¼Œç»§æ‰¿è‡ªJobBase并实现IJob接口 <br/>
    /// ç‰¹æ€§[DisallowConcurrentExecution]表示禁止并发执行
    /// </summary>
    /// <remarks>
    /// ä¸»è¦åŠŸèƒ½ï¼š <br/>
    /// 1. æ£€æŸ¥é¾™é—¨åŠçŠ¶æ€ï¼ˆè‡ªåŠ¨çŠ¶æ€/工作状态) <br/>
    /// 2. å¤„理取货/放货任务: <br/>
    ///    - éªŒè¯ä½ç½®åæ ‡æ ¼å¼ <br/>
    ///    - èŽ·å–æ¿æå°ºå¯¸ä¿¡æ¯ <br/>
    ///    - æ ¡éªŒå·¥ä½å’Œå®¹å™¨ä¿¡æ¯ <br/>
    ///    - è®¡ç®—并校验坐标范围 <br/>
    ///    - æ›´æ–°PLC控制参数 <br/>
    /// 3. å¤„理任务完成状态: <br/>
    ///    - æ›´æ–°ä»»åŠ¡çŠ¶æ€ <br/>
    ///    - é€šçŸ¥MES系统 <br/>
    ///    - é‡ç½®å·¥ä½çŠ¶æ€ <br/>
    /// 4. é”™è¯¯å¤„理:记录各种校验失败的异常情况 <br/>
    /// ä¾èµ–多个仓储和服务接口进行数据操作
    /// </remarks>
    [DisallowConcurrentExecution]
    public class GantryJob : JobBase, IJob
    {
        private readonly ITaskRepository _taskRepository;
        private readonly ITaskService _taskService;
        public GantryJob(ITaskRepository taskRepository, ITaskService taskService)
        private readonly IContainerItemRepository _containerItemRepository;
        private readonly WebSocketServer _webSocketServer;
        private readonly IOrderDetailsService _orderDetailsService;
        private readonly IContainerRepository _containerRepository;
        private readonly IOrderContainerRepository _orderContainerRepository;
        public GantryJob(ITaskRepository taskRepository, ITaskService taskService, IContainerItemRepository containerItemRepository, WebSocketServer webSocketServer, IOrderDetailsService orderDetailsService, IContainerRepository containerRepository, IOrderContainerRepository orderContainerRepository)
        {
            _taskRepository = taskRepository;
            _taskService = taskService;
            _containerItemRepository = containerItemRepository;
            _webSocketServer = webSocketServer;
            _orderDetailsService = orderDetailsService;
            _containerRepository = containerRepository;
            _orderContainerRepository = orderContainerRepository;
        }
        public Task Execute(IJobExecutionContext context)
        {
            try
            bool flag = context.JobDetail.JobDataMap.TryGetValue("JobParams", out object? value);
            if (flag && value is OtherDevice otherDevice)
            {
                bool flag = context.JobDetail.JobDataMap.TryGetValue("JobParams", out object? value);
                if (flag && value != null && value is OtherDevice)
                try
                {
                    OtherDevice otherDevice = (OtherDevice)value;
                    byte gantryStatus = otherDevice.GetValue<GantryDBName, byte>(GantryDBName.GantryStatus);
                    byte gantryAutoStatus = otherDevice.GetValue<GantryDBName, byte>(GantryDBName.GantryAutoStatus);
                    byte gantryWorkStatus = otherDevice.GetValue<GantryDBName, byte>(GantryDBName.GantryWorkStatus);
                    if(gantryStatus == 1 && gantryAutoStatus == 3 && gantryWorkStatus == 0)
                    if (gantryStatus == 1 && gantryAutoStatus == 3 && gantryWorkStatus == 0)
                    {
                        // é€»è¾‘处理
                        // 1. è¯»å–任务
                        // 2. ä»»åŠ¡æ‰§è¡Œ
                        // 3. ä»»åŠ¡å®Œæˆ
                        Dt_Task? task = _taskService.QueryAGantryUnExecuteTask(otherDevice.DeviceCode);
                        if(task != null)
                        if (task != null)
                        {
                            string[] takePositions = task.CurrentAddress.Split("-");
                            if(takePositions.Length != 4)
                            #region å–货位置判断
                            string[] takePositions = task.CurrentAddress.Split("*");
                            if (takePositions.Length != 5)
                            {
                                //WriteError
                                WriteError($"{otherDevice.DeviceCode}-{otherDevice.DeviceName}", "取货位置错误");
                                if (task.ExceptionMessage?.Contains("取货位置错误") ?? true)
                                {
                                    task.ExceptionMessage = "取货位置错误";
                                    _taskRepository.UpdateData(task);
                                }
                                return Task.CompletedTask;
                            }
                            #endregion
                            #region æ”¾è´§ä½ç½®åˆ¤æ–­
                            string[] putPositions = task.NextAddress.Split("*");
                            if (putPositions.Length != 5)
                            {
                                WriteError($"{otherDevice.DeviceCode}-{otherDevice.DeviceName}", "放货位置错误");
                                if (task.ExceptionMessage?.Contains("放货位置错误") ?? true)
                                {
                                    task.ExceptionMessage = "放货位置错误";
                                    _taskRepository.UpdateData(task);
                                }
                                return Task.CompletedTask;
                            }
                            #endregion
                            #region æ¿æå°ºå¯¸èŽ·å–
                            Dt_ContainerItem containerItem = _containerItemRepository.QueryFirst(x => x.ItemCode == task.PalletCode);
                            if (containerItem == null)
                            {
                                WriteError($"{otherDevice.DeviceCode}-{otherDevice.DeviceName}", "板材尺寸获取错误");
                                if (task.ExceptionMessage?.Contains("板材尺寸获取错误") ?? true)
                                {
                                    task.ExceptionMessage = "板材尺寸获取错误";
                                    _taskRepository.UpdateData(task);
                                }
                                if (LightStatusStorage.LightStatusDic.ContainsKey(putPositions[0]))
                                {
                                    LightStatusStorage.LightStatusDic[putPositions[0]] = LightStatusEnum.LightError;
                                }
                                return Task.CompletedTask;
                            }
                            #endregion
                            #region æ”¾è´§å·¥ä½åˆ¤æ–­
                            Dt_Container container = _containerRepository.QueryFirst(x => x.ContainerCode == putPositions[0]);
                            if (container == null)
                            {
                                WriteError($"{otherDevice.DeviceCode}-{otherDevice.DeviceName}", $"放货工位【{takePositions[0]}】未找到");
                                if (task.ExceptionMessage?.Contains($"放货工位【{takePositions[0]}】未找到") ?? true)
                                {
                                    task.ExceptionMessage = $"放货工位【{takePositions[0]}】未找到";
                                    _taskRepository.UpdateData(task);
                                }
                                if (LightStatusStorage.LightStatusDic.ContainsKey(putPositions[0]))
                                {
                                    LightStatusStorage.LightStatusDic[putPositions[0]] = LightStatusEnum.LightError;
                                }
                                return Task.CompletedTask;
                            }
                            #endregion
                            #region å·¥ä½è®¢å•信息判断
                            Dt_OrderContainer orderContainer = _orderContainerRepository.QueryFirst(x => x.ContainerCode == putPositions[0] && x.ContainerId == container.Id);
                            if (orderContainer == null && container.ContainerType != ContainerTypeEnum.ExceptionContainer.ObjToInt())
                            {
                                WriteError($"{otherDevice.DeviceCode}-{otherDevice.DeviceName}", $"放货工位【{takePositions[0]}】未找到订单信息");
                                if (task.ExceptionMessage?.Contains($"放货工位【{takePositions[0]}】未找到订单信息") ?? true)
                                {
                                    task.ExceptionMessage = $"放货工位【{takePositions[0]}】未找到订单信息";
                                    _taskRepository.UpdateData(task);
                                }
                                if (LightStatusStorage.LightStatusDic.ContainsKey(putPositions[0]))
                                {
                                    LightStatusStorage.LightStatusDic[putPositions[0]] = LightStatusEnum.LightError;
                                }
                                return Task.CompletedTask;
                            }
                            #endregion
                            #region å·¥ä½åž«æ¿è¯»å–数据判断
                            if (!LightStatusStorage.StationStautsDic.TryGetValue(putPositions[0], out bool stationStatus))
                            {
                                WriteError($"{otherDevice.DeviceCode}-{otherDevice.DeviceName}", $"工位【{putPositions[0]}】有无垫板数据错误,{LightStatusStorage.StationStautsDic.Serialize()}");
                                if (task.ExceptionMessage?.Contains($"工位【{putPositions[0]}】有无垫板数据错误") ?? true)
                                {
                                    task.ExceptionMessage = $"工位【{putPositions[0]}】有无垫板数据错误";
                                    _taskRepository.UpdateData(task);
                                }
                                if (LightStatusStorage.LightStatusDic.ContainsKey(putPositions[0]))
                                {
                                    LightStatusStorage.LightStatusDic[putPositions[0]] = LightStatusEnum.LightError;
                                }
                                return Task.CompletedTask;
                            }
                            #endregion
                            #region å·¥ä½åž«æ¿çŠ¶æ€åˆ¤æ–­
                            if (!stationStatus)
                            {
                                WriteError($"{otherDevice.DeviceCode}-{otherDevice.DeviceName}", $"工位【{putPositions[0]}】无垫板,{LightStatusStorage.StationStautsDic.Serialize()}");
                                if (task.ExceptionMessage?.Contains($"工位【{putPositions[0]}】无垫板") ?? true)
                                {
                                    task.ExceptionMessage = $"工位【{putPositions[0]}】无垫板";
                                    _taskRepository.UpdateData(task);
                                }
                                return Task.CompletedTask;
                            }
                            #endregion
                            #region å–è´§Z坐标判断
                            if (OPositions.HPositions[takePositions[0]].PositionZ == 0)
                            {
                                WriteError($"{otherDevice.DeviceCode}-{otherDevice.DeviceName}", "读取取货Z坐标读取为0");
                                if (task.ExceptionMessage?.Contains($"读取取货Z坐标读取为0") ?? true)
                                {
                                    task.ExceptionMessage = $"读取取货Z坐标读取为0";
                                    _taskRepository.UpdateData(task);
                                }
                                if (LightStatusStorage.LightStatusDic.ContainsKey(putPositions[0]))
                                {
                                    LightStatusStorage.LightStatusDic[putPositions[0]] = LightStatusEnum.LightError;
                                }
                                return Task.CompletedTask;
                            }
                            #endregion
                            #region æ”¾è´§Z坐标判断
                            if (OPositions.HPositions[putPositions[0]].PositionZ == 0)
                            {
                                WriteError($"{otherDevice.DeviceCode}-{otherDevice.DeviceName}", "读取放货Z坐标读取为0");
                                if (task.ExceptionMessage?.Contains($"读取放货Z坐标读取为0") ?? true)
                                {
                                    task.ExceptionMessage = $"读取放货Z坐标读取为0";
                                    _taskRepository.UpdateData(task);
                                }
                                if (LightStatusStorage.LightStatusDic.ContainsKey(putPositions[0]))
                                {
                                    LightStatusStorage.LightStatusDic[putPositions[0]] = LightStatusEnum.LightError;
                                }
                                return Task.CompletedTask;
                            }
                            #endregion
                            #region ä»»åŠ¡å®žä½“å‚æ•°è½¬æ¢å¤„ç†
                            int takePoX = Convert.ToInt32(takePositions[1]);
                            int takePoY = Convert.ToInt32(takePositions[2]);
                            int takePoZ = OPositions.HPositions[takePositions[0]].PositionZ + 30 * 1000 - Convert.ToInt32(takePositions[3]) * 1000;
                            int takePoR = 0;
                            int putPoX = Convert.ToInt32(putPositions[1]);
                            int putPoY = Convert.ToInt32(putPositions[2]);
                            int putPoZ = OPositions.HPositions[putPositions[0]].PositionZ - Convert.ToInt32(putPositions[3]) * 1000;
                            int putPoR = 0;
                            #endregion
                            #region åæ ‡ä¹˜ä»¥1000处理,2#龙门架取反(乘以-1000)
                            int temp = 1000;
                            if (otherDevice.DeviceCode == "GT02")
                            {
                                temp = -1000;
                            }
                            #endregion
                            #region åæ ‡è®¡ç®—
                            if (Convert.ToInt32(takePositions[4]) == 1 || Convert.ToInt32(takePositions[4]) == 2)
                            {
                                takePoX = takePoX * temp + OPositions.HPositions[takePositions[0]].PositionX;
                                takePoY = takePoY * temp + OPositions.HPositions[takePositions[0]].PositionY;
                                putPoX = putPoX * temp + OPositions.HPositions[putPositions[0]].PositionX;
                                putPoY = putPoY * temp + OPositions.HPositions[putPositions[0]].PositionY;
                                takePoR = OPositions.HPositions[takePositions[0]].PositionR;
                                if (Convert.ToInt32(takePositions[4]) == 1)
                                    putPoR = OPositions.HPositions[putPositions[0]].PositionR;
                                else
                                {
                                    if (otherDevice.DeviceCode == "GT03")
                                        putPoR = otherDevice.Communicator.Read<int>("DB10.840");
                                    else if (otherDevice.DeviceCode == "GT02")
                                        putPoR = otherDevice.Communicator.Read<int>("DB10.836");
                                    else if (otherDevice.DeviceCode == "GT01")
                                        putPoR = otherDevice.Communicator.Read<int>("DB10.832");
                                    else
                                    {
                                        WriteError($"{otherDevice.DeviceCode}-{otherDevice.DeviceName}", "R坐标错误");
                                        if (task.ExceptionMessage?.Contains($"R坐标错误") ?? true)
                                        {
                                            task.ExceptionMessage = $"R坐标错误";
                                            _taskRepository.UpdateData(task);
                                        }
                                        if (LightStatusStorage.LightStatusDic.ContainsKey(putPositions[0]))
                                        {
                                            LightStatusStorage.LightStatusDic[putPositions[0]] = LightStatusEnum.LightError;
                                        }
                                        return Task.CompletedTask;
                                    }
                                }
                            }
                            else
                            {
                                takePoX = takePoX * temp + OPositions.ZPositions[takePositions[0]].PositionX;
                                takePoY = takePoY * temp + OPositions.ZPositions[takePositions[0]].PositionY;
                                putPoX = putPoX * temp + OPositions.ZPositions[putPositions[0]].PositionX;
                                putPoY = putPoY * temp + OPositions.ZPositions[putPositions[0]].PositionY;
                                takePoR = OPositions.ZPositions[takePositions[0]].PositionR;
                                putPoR = OPositions.ZPositions[putPositions[0]].PositionR;
                            }
                            #endregion
                            #region Debug日志记录,记录取货和放货坐标信息
                            WriteDebug($"{otherDevice.DeviceCode}-{otherDevice.DeviceName}-坐标", $"取货位:{takePositions[0]},放货位:{putPositions[0]}{Environment.NewLine}取货坐标:X:{takePoX} Y:{takePoY} Z:{takePoZ} R:{takePoR}{Environment.NewLine}放货坐标:X:{putPoX} Y:{putPoY} Z:{putPoZ} R:{putPoR}{Environment.NewLine}读取PLC取货坐标:X:{OPositions.HPositions[takePositions[0]].PositionX} Y:{OPositions.HPositions[takePositions[0]].PositionY} Z:{OPositions.HPositions[takePositions[0]].PositionZ} R:{OPositions.HPositions[takePositions[0]].PositionR}{Environment.NewLine}读取PLC放货坐标:X:{OPositions.HPositions[putPositions[0]].PositionX} Y:{OPositions.HPositions[putPositions[0]].PositionY} Z:{OPositions.HPositions[putPositions[0]].PositionZ} R:{OPositions.HPositions[putPositions[0]].PositionR}");
                            #endregion
                            #region è¶…过容器宽度处理
                            bool isMoreWidth = orderContainer == null ? false : orderContainer.MaxWidth > container.ContainerWidth;
                            if (isMoreWidth)
                            {
                                putPoX = putPoX - (orderContainer.MaxWidth - container.ContainerWidth) / 2 * temp;
                            }
                            #endregion
                            #region åæ ‡èŒƒå›´åˆ¤æ–­
                            List<DeviceProDTO> devicePros = otherDevice.DeviceProDTOs.Where(x => x.DeviceProParamType == "MaxPosition").ToList();
                            DeviceProDTO? devicePro = devicePros.OrderBy(x => x.DeviceProOffset).FirstOrDefault();
                            if (devicePro == null)
                            {
                                WriteError($"{otherDevice.DeviceCode}-{otherDevice.DeviceName}", "设备协议参数错误,未找到最大最小坐标地址");
                                if (task.ExceptionMessage?.Contains($"设备协议参数错误,未找到最大最小坐标地址") ?? true)
                                {
                                    task.ExceptionMessage = $"设备协议参数错误,未找到最大最小坐标地址";
                                    _taskRepository.UpdateData(task);
                                }
                                if (LightStatusStorage.LightStatusDic.ContainsKey(putPositions[0]))
                                {
                                    LightStatusStorage.LightStatusDic[putPositions[0]] = LightStatusEnum.LightError;
                                }
                                return Task.CompletedTask;
                            }
                            string[] putPositions = task.NextAddress.Split("-");
                            if (putPositions.Length != 4)
                            int[] data = otherDevice.Communicator.Read<int>(devicePro.DeviceProAddress, (ushort)(devicePros.Count));
                            int maxX = data[0];
                            int minX = data[1];
                            int maxY = data[2];
                            int minY = data[3];
                            int maxZ = data[4];
                            int minZ = data[5];
                            int maxR = data[6];
                            int minR = data[7];
                            if (takePoX < minX || takePoX > maxX)
                            {
                                //WriteError
                                WriteError($"{otherDevice.DeviceCode}-{otherDevice.DeviceName}-坐标", $"X取货坐标超出范围,取货坐标:{takePoX},最大值:{maxX},最小值:{minX}");
                                if (task.ExceptionMessage?.Contains($"X取货坐标超出范围,取货坐标:{takePoX},最大值:{maxX},最小值:{minX}") ?? true)
                                {
                                    task.ExceptionMessage = $"X取货坐标超出范围,取货坐标:{takePoX},最大值:{maxX},最小值:{minX}";
                                    _taskRepository.UpdateData(task);
                                }
                                if (LightStatusStorage.LightStatusDic.ContainsKey(putPositions[0]))
                                {
                                    LightStatusStorage.LightStatusDic[putPositions[0]] = LightStatusEnum.LightError;
                                }
                                return Task.CompletedTask;
                            }
                            otherDevice.SetValue(GantryDBName.TwoHand, task.TaskNum);
                            if (putPoX < minX || putPoX > maxX)
                            {
                                WriteError($"{otherDevice.DeviceCode}-{otherDevice.DeviceName}-坐标", $"X放货坐标超出范围,取货坐标:{putPoX},最大值:{maxX},最小值:{minX}");
                                if (task.ExceptionMessage?.Contains($"X放货坐标超出范围,取货坐标:{putPoX},最大值:{maxX},最小值:{minX}") ?? true)
                                {
                                    task.ExceptionMessage = $"X放货坐标超出范围,取货坐标:{putPoX},最大值:{maxX},最小值:{minX}";
                                    _taskRepository.UpdateData(task);
                                }
                                if (LightStatusStorage.LightStatusDic.ContainsKey(putPositions[0]))
                                {
                                    LightStatusStorage.LightStatusDic[putPositions[0]] = LightStatusEnum.LightError;
                                }
                                return Task.CompletedTask;
                            }
                            if (takePoY < minY || takePoY > maxY)
                            {
                                WriteError($"{otherDevice.DeviceCode}-{otherDevice.DeviceName}-坐标", $"Y取货坐标超出范围,取货坐标:{takePoY},最大值:{maxY},最小值:{minY}");
                                if (task.ExceptionMessage?.Contains($"Y取货坐标超出范围,取货坐标:{takePoY},最大值:{maxY},最小值:{minY}") ?? true)
                                {
                                    task.ExceptionMessage = $"Y取货坐标超出范围,取货坐标:{takePoY},最大值:{maxY},最小值:{minY}";
                                    _taskRepository.UpdateData(task);
                                }
                                if (LightStatusStorage.LightStatusDic.ContainsKey(putPositions[0]))
                                {
                                    LightStatusStorage.LightStatusDic[putPositions[0]] = LightStatusEnum.LightError;
                                }
                                return Task.CompletedTask;
                            }
                            if (putPoY < minY || putPoY > maxY)
                            {
                                WriteError($"{otherDevice.DeviceCode}-{otherDevice.DeviceName}-坐标", $"Y放货坐标超出范围,取货坐标:{putPoY},最大值:{maxY},最小值:{minY}");
                                if (task.ExceptionMessage?.Contains($"Y放货坐标超出范围,取货坐标:{putPoY},最大值:{maxY},最小值:{minY}") ?? true)
                                {
                                    task.ExceptionMessage = $"Y放货坐标超出范围,取货坐标:{putPoY},最大值:{maxY},最小值:{minY}";
                                    _taskRepository.UpdateData(task);
                                }
                                if (LightStatusStorage.LightStatusDic.ContainsKey(putPositions[0]))
                                {
                                    LightStatusStorage.LightStatusDic[putPositions[0]] = LightStatusEnum.LightError;
                                }
                                return Task.CompletedTask;
                            }
                            if (takePoZ < minZ || takePoZ > maxZ)
                            {
                                WriteError($"{otherDevice.DeviceCode}-{otherDevice.DeviceName}-坐标", $"Z取货坐标超出范围,取货坐标:{takePoZ},最大值:{maxZ},最小值:{minZ}");
                                if (task.ExceptionMessage?.Contains($"Z取货坐标超出范围,取货坐标:{takePoZ},最大值:{maxZ},最小值:{minZ}") ?? true)
                                {
                                    task.ExceptionMessage = $"Z取货坐标超出范围,取货坐标:{takePoZ},最大值:{maxZ},最小值:{minZ}";
                                    _taskRepository.UpdateData(task);
                                }
                                if (LightStatusStorage.LightStatusDic.ContainsKey(putPositions[0]))
                                {
                                    LightStatusStorage.LightStatusDic[putPositions[0]] = LightStatusEnum.LightError;
                                }
                                return Task.CompletedTask;
                            }
                            if (putPoZ < minZ || putPoZ > maxZ)
                            {
                                WriteError($"{otherDevice.DeviceCode}-{otherDevice.DeviceName}-坐标", $"Z放货坐标超出范围,取货坐标:{putPoZ},最大值:{maxZ},最小值:{minZ}");
                                if (task.ExceptionMessage?.Contains($"Z放货坐标超出范围,取货坐标:{putPoZ},最大值:{maxZ},最小值:{minZ}") ?? true)
                                {
                                    task.ExceptionMessage = $"Z放货坐标超出范围,取货坐标:{putPoZ},最大值:{maxZ},最小值:{minZ}";
                                    _taskRepository.UpdateData(task);
                                }
                                if (LightStatusStorage.LightStatusDic.ContainsKey(putPositions[0]))
                                {
                                    LightStatusStorage.LightStatusDic[putPositions[0]] = LightStatusEnum.LightError;
                                }
                                return Task.CompletedTask;
                            }
                            if (takePoR < minR || takePoR > maxR)
                            {
                                WriteError($"{otherDevice.DeviceCode}-{otherDevice.DeviceName}-坐标", $"R取货坐标超出范围,取货坐标:{takePoR},最大值:{maxR},最小值:{minR}");
                                if (task.ExceptionMessage?.Contains($"R取货坐标超出范围,取货坐标:{takePoR},最大值:{maxR},最小值:{minR}") ?? true)
                                {
                                    task.ExceptionMessage = $"R取货坐标超出范围,取货坐标:{takePoR},最大值:{maxR},最小值:{minR}";
                                    _taskRepository.UpdateData(task);
                                }
                                if (LightStatusStorage.LightStatusDic.ContainsKey(putPositions[0]))
                                {
                                    LightStatusStorage.LightStatusDic[putPositions[0]] = LightStatusEnum.LightError;
                                }
                                return Task.CompletedTask;
                            }
                            if (putPoR < minR || putPoR > maxR)
                            {
                                WriteError($"{otherDevice.DeviceCode}-{otherDevice.DeviceName}-坐标", $"R放货坐标超出范围,取货坐标:{putPoR},最大值:{maxR},最小值:{minR}");
                                if (task.ExceptionMessage?.Contains($"R放货坐标超出范围,取货坐标:{putPoR},最大值:{maxR},最小值:{minR}") ?? true)
                                {
                                    task.ExceptionMessage = $"R放货坐标超出范围,取货坐标:{putPoR},最大值:{maxR},最小值:{minR}";
                                    _taskRepository.UpdateData(task);
                                }
                                if (LightStatusStorage.LightStatusDic.ContainsKey(putPositions[0]))
                                {
                                    LightStatusStorage.LightStatusDic[putPositions[0]] = LightStatusEnum.LightError;
                                }
                                return Task.CompletedTask;
                            }
                            #endregion
                            #region ä»»åŠ¡å‘é€
                            otherDevice.SetValue(GantryDBName.TwoHand, true);
                            otherDevice.SetValue(GantryDBName.TaskNum, task.TaskNum);
                            otherDevice.SetValue(GantryDBName.TakePosition, Convert.ToInt32(takePositions[0]));
                            otherDevice.SetValue(GantryDBName.TakePositionX, Convert.ToInt32(takePositions[1]));
                            otherDevice.SetValue(GantryDBName.TakePositionY, Convert.ToInt32(takePositions[2]));
                            otherDevice.SetValue(GantryDBName.TakePositionZ, Convert.ToInt32(takePositions[3]));
                            otherDevice.SetValue(GantryDBName.TakePositionR, 0);
                            otherDevice.SetValue(GantryDBName.PutPosition, Convert.ToInt32(putPositions[0]));
                            otherDevice.SetValue(GantryDBName.PutPositionX, Convert.ToInt32(putPositions[1]));
                            otherDevice.SetValue(GantryDBName.PutPositionY, Convert.ToInt32(putPositions[2]));
                            otherDevice.SetValue(GantryDBName.PutPositionZ, Convert.ToInt32(putPositions[3]));
                            otherDevice.SetValue(GantryDBName.PutPositionR, 0);
                            otherDevice.SetValue(GantryDBName.Length, task.TaskNum);
                            otherDevice.SetValue(GantryDBName.Width, task.TaskNum);
                            otherDevice.SetValue(GantryDBName.Height, task.TaskNum);
                            otherDevice.SetValue(GantryDBName.WorkType, task.TaskNum);
                            otherDevice.SetValue(GantryDBName.StartCommand, task.TaskNum);
                            otherDevice.SetValue(GantryDBName.TakePositionX, takePoX);
                            otherDevice.SetValue(GantryDBName.TakePositionY, takePoY);
                            otherDevice.SetValue(GantryDBName.TakePositionZ, takePoZ);
                            otherDevice.SetValue(GantryDBName.TakePositionR, takePoR);
                            otherDevice.SetValue(GantryDBName.PutPositionX, putPoX);
                            otherDevice.SetValue(GantryDBName.PutPositionY, putPoY);
                            otherDevice.SetValue(GantryDBName.PutPositionZ, putPoZ);
                            otherDevice.SetValue(GantryDBName.PutPositionR, putPoR);
                            otherDevice.SetValue(GantryDBName.Length, containerItem.ItemLength);
                            otherDevice.SetValue(GantryDBName.Width, containerItem.ItemWidth);
                            otherDevice.SetValue(GantryDBName.Height, containerItem.ItemHeight);
                            otherDevice.SetValue(GantryDBName.WorkType, 1);
                            otherDevice.SetValue(GantryDBName.StartCommand, 1);
                            #endregion
                            #region ä»»åŠ¡çŠ¶æ€æ›´æ–°
                            task.TaskState = TaskStatusEnum.Gantry_Executing.ObjToInt();
                            _taskRepository.UpdateData(task);
                            #endregion
                            #region ä¸‰è‰²ç¯çŠ¶æ€æ›´æ–°
                            if (LightStatusStorage.LightStatusDic.TryGetValue(putPositions[0], out LightStatusEnum lightStatusDic))
                            {
                                if (lightStatusDic != LightStatusEnum.LightWorking)
                                {
                                    LightStatusStorage.LightStatusDic[putPositions[0]] = LightStatusEnum.LightWorking;
                                }
                            }
                            #endregion
                        }
                    }
                    else if(gantryWorkStatus == 5)
                    else if (gantryWorkStatus == 5)
                    {
                        int currentTaskNum = otherDevice.GetValue<GantryDBName, int>(GantryDBName.TaskNum);
                        if (currentTaskNum > 0)
                        {
                            Dt_Task task = _taskRepository.QueryFirst(x => x.TaskNum == currentTaskNum);
                            if (task != null)
                            {
                                _taskService.TaskComplete(task);
                                Task.Run(() =>
                                {
                                    _orderDetailsService.ToMes(task.PalletCode, 4);
                                });
                                string[] putPositions = task.NextAddress.Split("*");
                                if (putPositions.Length != 5)
                                {
                                    return Task.CompletedTask;
                                }
                                if (LightStatusStorage.LightStatusDic.TryGetValue(putPositions[0], out LightStatusEnum lightStatusDic))
                                {
                                    if (lightStatusDic != LightStatusEnum.Ready)
                                    {
                                        LightStatusStorage.LightStatusDic[putPositions[0]] = LightStatusEnum.Ready;
                                    }
                                }
                            }
                        }
                        otherDevice.SetValue(GantryDBName.WorkType, 5);
                    }
                }
                catch (Exception ex)
                {
                    WriteError($"{otherDevice.DeviceCode}-{otherDevice.DeviceName}", ex.Message, ex);
                }
            }
            catch (Exception ex)
            else
            {
                WriteError(nameof(GantryJob), "参数错误,未传递设备参数或设备类型错误");
            }
            return Task.CompletedTask;
        }
        public Dt_Task GetTask()
        {
            return new Dt_Task();
        }
    }
}