|  |  |  | 
|---|
|  |  |  | using Newtonsoft.Json; | 
|---|
|  |  |  | using System; | 
|---|
|  |  |  | using System.Collections.Generic; | 
|---|
|  |  |  | using System.Linq; | 
|---|
|  |  |  | using System.Text; | 
|---|
|  |  |  | using Mapster; | 
|---|
|  |  |  | using Masuit.Tools; | 
|---|
|  |  |  | using Newtonsoft.Json; | 
|---|
|  |  |  | using System.Threading.Tasks; | 
|---|
|  |  |  | using WIDESEAWCS_Common; | 
|---|
|  |  |  | using WIDESEAWCS_Common.TaskEnum; | 
|---|
|  |  |  | using WIDESEAWCS_Core.Helper; | 
|---|
|  |  |  | using WIDESEAWCS_Core; | 
|---|
|  |  |  | using WIDESEAWCS_Core.Helper; | 
|---|
|  |  |  | using WIDESEAWCS_DTO.TaskInfo; | 
|---|
|  |  |  | using WIDESEAWCS_DTO.WMS; | 
|---|
|  |  |  | using WIDESEAWCS_Model.Models; | 
|---|
|  |  |  | using WIDESEAWCS_QuartzJob; | 
|---|
|  |  |  | using WIDESEAWCS_Tasks.ConveyorLineJob; | 
|---|
|  |  |  | using HslCommunication; | 
|---|
|  |  |  | using WIDESEAWCS_DTO.WMS; | 
|---|
|  |  |  | using WIDESEAWCS_Common; | 
|---|
|  |  |  | using static Microsoft.EntityFrameworkCore.DbLoggerCategory.Database; | 
|---|
|  |  |  |  | 
|---|
|  |  |  | namespace WIDESEAWCS_Tasks | 
|---|
|  |  |  | { | 
|---|
|  |  |  | 
|---|
|  |  |  | case 9: | 
|---|
|  |  |  | case 11: | 
|---|
|  |  |  | case 12: | 
|---|
|  |  |  | var task = _taskService.QueryExecutingConveyorLineTask(command.ConveyorLineTaskNum, childDeviceCode); | 
|---|
|  |  |  | var task = _taskService.QueryExecutingTaskByBarcode(command.ConveyorLineBarcode, childDeviceCode); | 
|---|
|  |  |  | if (task != null) | 
|---|
|  |  |  | { | 
|---|
|  |  |  | ExecuteStationAction(stationManager, conveyorLine, command, childDeviceCode); | 
|---|
|  |  |  | 
|---|
|  |  |  | case 10: | 
|---|
|  |  |  | ExecuteStationAction(stationManager, conveyorLine, command, childDeviceCode); | 
|---|
|  |  |  | break; | 
|---|
|  |  |  | //case 16: | 
|---|
|  |  |  | //    ExecuteStationAction(stationManager, conveyorLine, command, childDeviceCode); | 
|---|
|  |  |  | //    break; | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | #region | 
|---|
|  |  |  | 
|---|
|  |  |  | //    } | 
|---|
|  |  |  | //} | 
|---|
|  |  |  | #endregion | 
|---|
|  |  |  |  | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | private void ExecuteStationAction(Dt_StationManager stationManager, CommonConveyorLine_GW conveyorLine, ConveyorLineTaskCommand_After command, string childDeviceCode) | 
|---|
|  |  |  | 
|---|
|  |  |  | case 8: | 
|---|
|  |  |  | RequestInNextAddress(conveyorLine, command, childDeviceCode); | 
|---|
|  |  |  | break; | 
|---|
|  |  |  |  | 
|---|
|  |  |  | case 9: | 
|---|
|  |  |  | ConveyorLineInFinish(conveyorLine, command, childDeviceCode); | 
|---|
|  |  |  | break; | 
|---|
|  |  |  |  | 
|---|
|  |  |  | case 10: | 
|---|
|  |  |  | RequestOutbound(conveyorLine, command, childDeviceCode); | 
|---|
|  |  |  | break; | 
|---|
|  |  |  |  | 
|---|
|  |  |  | case 11: | 
|---|
|  |  |  | RequestOutNextAddress(conveyorLine, command, childDeviceCode); | 
|---|
|  |  |  | break; | 
|---|
|  |  |  |  | 
|---|
|  |  |  | case 12: | 
|---|
|  |  |  | ConveyorLineOutFinish(conveyorLine, command, childDeviceCode); | 
|---|
|  |  |  | break; | 
|---|
|  |  |  |  | 
|---|
|  |  |  | case 6: | 
|---|
|  |  |  | CreateAndSendEmptyTrayTask(conveyorLine,command, childDeviceCode); | 
|---|
|  |  |  | CreateAndSendEmptyTrayTask(conveyorLine, command, childDeviceCode); | 
|---|
|  |  |  | break; | 
|---|
|  |  |  | case 16: | 
|---|
|  |  |  | AbNormalStationBZTask(conveyorLine, command, childDeviceCode); | 
|---|
|  |  |  | break; | 
|---|
|  |  |  | case 1: | 
|---|
|  |  |  | if (stationManager.stationArea.Contains("GW")) | 
|---|
|  |  |  | { | 
|---|
|  |  |  | var taskGW = _taskRepository.QueryFirst(x => x.TargetAddress == childDeviceCode && (x.TaskState == (int)TaskOutStatusEnum.OutFinish|| x.TaskState == (int)TaskOutStatusEnum.OutPending)); | 
|---|
|  |  |  | if (taskGW != null) | 
|---|
|  |  |  | { | 
|---|
|  |  |  | command.ConveyorLineBarcode = taskGW.PalletCode; | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | RequestWmsTask(conveyorLine, command, childDeviceCode); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | //if (stationManager.stationArea.Contains("GW")) | 
|---|
|  |  |  | //{ | 
|---|
|  |  |  | //var taskGW = _taskRepository.QueryFirst(x => x.TargetAddress == childDeviceCode && (x.TaskState == (int)TaskOutStatusEnum.OutFinish || x.TaskState == (int)TaskOutStatusEnum.OutPending)); | 
|---|
|  |  |  | //if (taskGW != null) | 
|---|
|  |  |  | //{ | 
|---|
|  |  |  | //    command.ConveyorLineBarcode = taskGW.PalletCode; | 
|---|
|  |  |  | //} | 
|---|
|  |  |  | //} | 
|---|
|  |  |  | //如高温出库后任务标记NG异常则将任务更新为异常排出任务   --冠宇取消超时检测后  托盘超时不在出库至异常口 | 
|---|
|  |  |  | //Dt_Task NGtask = _taskRepository.QueryFirst(x => x.Remark == "NG" && x.Roadway == stationManager.Roadway && x.Roadway.Contains("GW")); | 
|---|
|  |  |  | //if (NGtask != null) | 
|---|
|  |  |  | //{ | 
|---|
|  |  |  | //    CreateAbNormalOutbound(conveyorLine, command, childDeviceCode, NGtask); | 
|---|
|  |  |  | //    break; | 
|---|
|  |  |  | //} | 
|---|
|  |  |  |  | 
|---|
|  |  |  | RequestWmsTask(conveyorLine, command, childDeviceCode, stationManager); | 
|---|
|  |  |  | break; | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | 
|---|
|  |  |  | { | 
|---|
|  |  |  | var taskDTO = CreateEmptyTrayTaskDto(command.ConveyorLineBarcode, childDeviceCode); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | if (_taskRepository.QueryFirst(x => x.PalletCode == taskDTO.PalletCode) != null) | 
|---|
|  |  |  | if (_taskRepository.QueryFirst(x => x.PalletCode == command.ConveyorLineBarcode) != null) | 
|---|
|  |  |  | { | 
|---|
|  |  |  | WriteInfo(conveyorLine.DeviceName, "当前托盘存在任务"); | 
|---|
|  |  |  | return; | 
|---|
|  |  |  | List<string> strings = new List<string>() { "1743", "1739", "1837", "1841" }; | 
|---|
|  |  |  |  | 
|---|
|  |  |  | var taskExecuting = _taskRepository.QueryFirst(x => x.PalletCode == command.ConveyorLineBarcode && x.TaskState == (int)TaskOutStatusEnum.Line_OutExecuting && strings.Contains(x.TargetAddress)); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | if (taskExecuting != null) | 
|---|
|  |  |  | { | 
|---|
|  |  |  | taskExecuting.ExceptionMessage = "未接收到线体完成信号系统内部自动完成"; | 
|---|
|  |  |  | _taskService.Delete(taskExecuting); | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | ConsoleHelper.WriteErrorLine($"当前托盘存在任务:【{command.ConveyorLineBarcode}】"); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | WriteInfo(conveyorLine.DeviceName, $"当前托盘存在任务{command.ConveyorLineBarcode}"); | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | var content = CreateAndSendTask(taskDTO); | 
|---|
|  |  |  | if (content.Status) | 
|---|
|  |  |  | { | 
|---|
|  |  |  | var task = _taskService.QueryConveyorLineTask(conveyorLine.DeviceCode, childDeviceCode); | 
|---|
|  |  |  | var task = _taskService.QueryConveyorLineTask(conveyorLine.DeviceCode, childDeviceCode, command.ConveyorLineBarcode); | 
|---|
|  |  |  | if (task != null) | 
|---|
|  |  |  | { | 
|---|
|  |  |  | var taskCommand = MapTaskCommand(task, command); | 
|---|
|  |  |  | conveyorLine.SendCommand(taskCommand, childDeviceCode); | 
|---|
|  |  |  | //ConveyorLineSendFinish(conveyorLine, childDeviceCode, true); | 
|---|
|  |  |  | _taskService.UpdateTaskStatusToNext(task); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | bool sendFlag = SendCommand(taskCommand, conveyorLine, childDeviceCode); | 
|---|
|  |  |  | if (sendFlag) | 
|---|
|  |  |  | { | 
|---|
|  |  |  | _taskService.UpdateTaskStatusToNext(task); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | 
|---|
|  |  |  | /// <summary> | 
|---|
|  |  |  | /// 请求WMS任务 | 
|---|
|  |  |  | /// </summary> | 
|---|
|  |  |  | private async void RequestWmsTask(CommonConveyorLine_GW conveyorLine, ConveyorLineTaskCommand_After command, string childDeviceCode) | 
|---|
|  |  |  | private async void RequestWmsTask(CommonConveyorLine_GW conveyorLine, ConveyorLineTaskCommand_After command, string childDeviceCode, Dt_StationManager stationManager) | 
|---|
|  |  |  | { | 
|---|
|  |  |  | var taskGW = _taskRepository.QueryFirst(x => x.TargetAddress == childDeviceCode && (x.TaskState == (int)TaskOutStatusEnum.OutFinish || x.TaskState == (int)TaskOutStatusEnum.OutPending)); | 
|---|
|  |  |  | if (taskGW != null) | 
|---|
|  |  |  | _taskRepository.DeleteData(taskGW); | 
|---|
|  |  |  | var content = await _taskService.RequestWMSTask(command.ConveyorLineBarcode, childDeviceCode); | 
|---|
|  |  |  | if (content.Status) | 
|---|
|  |  |  | try | 
|---|
|  |  |  | { | 
|---|
|  |  |  | var task = _taskService.QueryBarCodeConveyorLineTask(command.ConveyorLineBarcode, childDeviceCode); | 
|---|
|  |  |  | if (task != null) | 
|---|
|  |  |  | if (command.ConveyorLineBarcode.IsNullOrEmpty()) return; | 
|---|
|  |  |  | var content = await _taskService.RequestWMSTask(command.ConveyorLineBarcode, childDeviceCode); | 
|---|
|  |  |  | if (content.Status) | 
|---|
|  |  |  | { | 
|---|
|  |  |  | //conveyorLine.SetValue(ConveyorLineDBName_After.ConveyorLineTaskNum, task.TaskNum, childDeviceCode); | 
|---|
|  |  |  | //conveyorLine.SetValue(ConveyorLineDBName_After.ConveyorLineTargetAddress, task.NextAddress, childDeviceCode); | 
|---|
|  |  |  | //conveyorLine.SetValue(ConveyorLineDBName_After.ConveyorLineBarcode, command.ConveyorLineBarcode, childDeviceCode); | 
|---|
|  |  |  | ConveyorLineTaskCommand_After taskCommand = _mapper.Map<ConveyorLineTaskCommand_After>(task); | 
|---|
|  |  |  | conveyorLine.SetValue(ConveyorLineDBName_After.ResponState, 1, childDeviceCode); | 
|---|
|  |  |  | conveyorLine.SendCommand(taskCommand, childDeviceCode); | 
|---|
|  |  |  | //ConveyorLineSendFinish(conveyorLine, childDeviceCode, ProtocalDetailValue, true); | 
|---|
|  |  |  | _taskService.UpdateTaskStatusToNext(task); | 
|---|
|  |  |  | var task = _taskService.QueryBarCodeConveyorLineTask(command.ConveyorLineBarcode, childDeviceCode); | 
|---|
|  |  |  | if (task != null) | 
|---|
|  |  |  | { | 
|---|
|  |  |  | if (childDeviceCode == "1039") | 
|---|
|  |  |  | { | 
|---|
|  |  |  | var GWTask = _taskRepository.QueryData(x => x.Roadway.Contains("GWSC2") && x.SourceAddress == "1039" && (x.TaskState == (int)TaskInStatusEnum.Line_InExecuting || x.TaskState == (int)TaskInStatusEnum.Line_InFinish)).ToList(); | 
|---|
|  |  |  | if (GWTask.Count >= 2 && childDeviceCode == "1039" && task.Roadway.Contains("GWSC2")) | 
|---|
|  |  |  | { | 
|---|
|  |  |  | ConsoleHelper.WriteErrorLine($"托盘号:【{command.ConveyorLineBarcode}】高温二已存在【{GWTask.Count}】个任务大于2个任务不可下发"); | 
|---|
|  |  |  | return; | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | ConveyorLineTaskCommand_After taskCommand = _mapper.Map<ConveyorLineTaskCommand_After>(task); | 
|---|
|  |  |  | //conveyorLine.SendCommand(taskCommand, childDeviceCode); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | bool sendFlag = SendCommand(taskCommand, conveyorLine, childDeviceCode); | 
|---|
|  |  |  | if (sendFlag) | 
|---|
|  |  |  | { | 
|---|
|  |  |  | conveyorLine.SetValue(ConveyorLineDBName_After.ResponState, Convert.ToInt16(1), childDeviceCode); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | _taskService.UpdateTaskStatusToNext(task); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | else | 
|---|
|  |  |  | { | 
|---|
|  |  |  | if (content.Message != "请求过于频繁,请稍后再试" && content.Message != "无法获取目标地址") | 
|---|
|  |  |  | { | 
|---|
|  |  |  | WriteInfo(conveyorLine.DeviceName, content.Message); | 
|---|
|  |  |  | conveyorLine.SetValue(ConveyorLineDBName_After.ConveyorLineTargetAddress, stationManager.stationNGChildCode, childDeviceCode); | 
|---|
|  |  |  | conveyorLine.SetValue(ConveyorLineDBName_After.ResponState, Convert.ToInt16(1), childDeviceCode); | 
|---|
|  |  |  | ConsoleHelper.WriteErrorLine($"【{conveyorLine.DeviceName}】托盘号:【{command.ConveyorLineBarcode}】请求点位:【{childDeviceCode}】异常信息【{content.Message}】"); | 
|---|
|  |  |  | WriteInfo(conveyorLine.DeviceName, $"【{conveyorLine.DeviceName}】托盘号:【{command.ConveyorLineBarcode}】请求点位:【{childDeviceCode}】异常信息【{content.Message}】"); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | ConsoleHelper.WriteErrorLine($"【{conveyorLine.DeviceName}】托盘号:【{command.ConveyorLineBarcode}】请求点位:【{childDeviceCode}】异常信息【{content.Message}】"); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | else | 
|---|
|  |  |  | catch (Exception ex) | 
|---|
|  |  |  | { | 
|---|
|  |  |  | WriteInfo(conveyorLine.DeviceName, content.Message); | 
|---|
|  |  |  | _taskRepository.AddData(taskGW); | 
|---|
|  |  |  | WriteInfo(conveyorLine.DeviceName, $"【{conveyorLine.DeviceName}】托盘号:【{command.ConveyorLineBarcode}】请求点位:【{childDeviceCode}】异常信息【{ex.Message}】异常行【{ex.StackTrace}】"); | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | /// <summary> | 
|---|
|  |  |  | /// 高温出库后任务完成 如果任务标识NG则将任务改为异常排出任务 | 
|---|
|  |  |  | /// </summary> | 
|---|
|  |  |  | /// <param name="conveyorLine"></param> | 
|---|
|  |  |  | /// <param name="command"></param> | 
|---|
|  |  |  | /// <param name="childDeviceCode"></param> | 
|---|
|  |  |  | /// <param name="task"></param> | 
|---|
|  |  |  | /// <exception cref="Exception"></exception> | 
|---|
|  |  |  | private void CreateAbNormalOutbound(CommonConveyorLine_GW conveyorLine, ConveyorLineTaskCommand_After command, string childDeviceCode, Dt_Task task) | 
|---|
|  |  |  | { | 
|---|
|  |  |  | Dt_StationManager stationManager = _stationManagerRepository.QueryFirst(x => x.stationChildCode == childDeviceCode); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | if (stationManager == null || string.IsNullOrWhiteSpace(stationManager.stationNGChildCode) || string.IsNullOrWhiteSpace(stationManager.stationNGLocation)) | 
|---|
|  |  |  | { | 
|---|
|  |  |  | throw new Exception("未配置站台的对应NG口信息"); | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | task.SourceAddress = task.TargetAddress; | 
|---|
|  |  |  | task.TargetAddress = stationManager.stationNGLocation; | 
|---|
|  |  |  | task.TaskState = (int)TaskOutStatusEnum.OutNew; | 
|---|
|  |  |  | task.TaskType = (int)TaskOutboundTypeEnum.InToOut; | 
|---|
|  |  |  | task.Grade = 10;    //此处 出库至异常排出口的任务应除火警外最优先执行 | 
|---|
|  |  |  |  | 
|---|
|  |  |  | _taskRepository.UpdateData(task); | 
|---|
|  |  |  | //Dt_Task task= _taskRepository.QueryFirst(x=>) | 
|---|
|  |  |  | //_taskRepository.QueryFirst() | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | /// <summary> | 
|---|
|  |  |  | /// 包装异常排出口逻辑 | 
|---|
|  |  |  | /// </summary> | 
|---|
|  |  |  | /// <param name="conveyorLine"></param> | 
|---|
|  |  |  | /// <param name="command"></param> | 
|---|
|  |  |  | /// <param name="childDeviceCode"></param> | 
|---|
|  |  |  | private void AbNormalStationBZTask(CommonConveyorLine_GW conveyorLine, ConveyorLineTaskCommand_After command, string childDeviceCode) | 
|---|
|  |  |  | { | 
|---|
|  |  |  | Dt_StationManager stationManager = _stationManagerRepository.QueryFirst(x => x.stationChildCode == childDeviceCode && x.stationPLC == conveyorLine.DeviceCode); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | if (command.ConveyorLineBarcode.IsNullOrEmpty()) | 
|---|
|  |  |  | { | 
|---|
|  |  |  | conveyorLine.SetValue(ConveyorLineDBName_After.ResponState, Convert.ToInt16(1), childDeviceCode); | 
|---|
|  |  |  | return; | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  |  | 
|---|
|  |  |  | if (conveyorLine.ReadValue(ConveyorLineDBName_After.InteractiveSignal, childDeviceCode).ObjToInt() == 0) //托盘正反信号 | 
|---|
|  |  |  | { | 
|---|
|  |  |  |  | 
|---|
|  |  |  | } | 
|---|
|  |  |  | ; | 
|---|
|  |  |  | conveyorLine.ReadValue(ConveyorLineDBName_After.InteractiveSignal, childDeviceCode);  //托盘有无电芯信号 | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|