|  |  |  | 
|---|
|  |  |  | using Newtonsoft.Json; | 
|---|
|  |  |  | using System; | 
|---|
|  |  |  | using System.Collections.Generic; | 
|---|
|  |  |  | using System.Linq; | 
|---|
|  |  |  | using System.Text; | 
|---|
|  |  |  | using HslCommunication; | 
|---|
|  |  |  | using Mapster; | 
|---|
|  |  |  | using Newtonsoft.Json; | 
|---|
|  |  |  | using System.Text.RegularExpressions; | 
|---|
|  |  |  | 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 System.Text.RegularExpressions; | 
|---|
|  |  |  |  | 
|---|
|  |  |  | namespace WIDESEAWCS_Tasks | 
|---|
|  |  |  | { | 
|---|
|  |  |  | 
|---|
|  |  |  | { | 
|---|
|  |  |  | conveyorLine.SendCommand(taskCommand, childDeviceCode); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | ConsoleHelper.WriteWarningLine($"【{conveyorLine._deviceName}】任务号:【{command.TaskNum}】,托盘条码:【{command.Barcode}】已到达【{childDeviceCode}】请求扫码入库,下一目标地址【{taskCommand.TargetAddress}】"); | 
|---|
|  |  |  | var log = $"【{conveyorLine._deviceName}】任务号:【{command.TaskNum}】,托盘条码:【{command.Barcode}】已到达【{childDeviceCode}】请求扫码入库,下一目标地址【{taskCommand.TargetAddress}】"; | 
|---|
|  |  |  | ConsoleHelper.WriteWarningLine(log); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | _noticeService.Logs(userTokenIds, new { conveyorLine.DeviceName, log = log, time = DateTime.Now.ToString("G"), color = "red" }); | 
|---|
|  |  |  | WriteInfo(conveyorLine.DeviceName, log); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | ConveyorLineSendFinish(conveyorLine, childDeviceCode, ProtocalDetailValue, true); | 
|---|
|  |  |  | _taskService.UpdateTaskStatusToNext(taskOut); | 
|---|
|  |  |  | 
|---|
|  |  |  | /// <summary> | 
|---|
|  |  |  | /// 处理新任务 | 
|---|
|  |  |  | /// </summary> | 
|---|
|  |  |  | private async void HandleNewTask(CommonConveyorLine conveyorLine, ConveyorLineTaskCommand command, string childDeviceCode, int ProtocalDetailValue) | 
|---|
|  |  |  | public async Task HandleNewTaskAsync(CommonConveyorLine conveyorLine, ConveyorLineTaskCommand command, string childDeviceCode, int ProtocalDetailValue) | 
|---|
|  |  |  | { | 
|---|
|  |  |  | var stationManager = _stationManagerRepository.QueryFirst(x => x.stationChildCode == childDeviceCode && x.stationPLC == conveyorLine.DeviceCode); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | switch (stationManager.stationType) | 
|---|
|  |  |  | { | 
|---|
|  |  |  | case 5: | 
|---|
|  |  |  | case 1: | 
|---|
|  |  |  | await RequestWmsTask(conveyorLine, command, childDeviceCode, ProtocalDetailValue); | 
|---|
|  |  |  | break; | 
|---|
|  |  |  |  | 
|---|
|  |  |  | case 2: | 
|---|
|  |  |  | case 3: | 
|---|
|  |  |  | case 4: | 
|---|
|  |  |  | case 5: | 
|---|
|  |  |  | case 6: | 
|---|
|  |  |  | await CreateAndSendEmptyTrayTask(conveyorLine, command, childDeviceCode, ProtocalDetailValue); | 
|---|
|  |  |  | break; | 
|---|
|  |  |  |  | 
|---|
|  |  |  | case 7: | 
|---|
|  |  |  | RequestOutNextAddress(conveyorLine, command, childDeviceCode, ProtocalDetailValue); | 
|---|
|  |  |  | break; | 
|---|
|  |  |  |  | 
|---|
|  |  |  | case 10: | 
|---|
|  |  |  | ConveyorLineOutFinish(conveyorLine, command, childDeviceCode, ProtocalDetailValue); | 
|---|
|  |  |  | break; | 
|---|
|  |  |  |  | 
|---|
|  |  |  | default: | 
|---|
|  |  |  | break; | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | //if ((conveyorLine.DeviceCode == "1003" && childDeviceCode == "1016") || (conveyorLine.DeviceCode == "1005" && childDeviceCode == "1048")) | 
|---|
|  |  |  | //{ | 
|---|
|  |  |  | //    await CreateAndSendEmptyTrayTask(conveyorLine, command, childDeviceCode, ProtocalDetailValue); | 
|---|
|  |  |  | //} | 
|---|
|  |  |  | //else if ((conveyorLine.DeviceCode == "1001" && childDeviceCode == "1088") || (conveyorLine.DeviceCode == "1004" && childDeviceCode == "1339")) | 
|---|
|  |  |  | //{ | 
|---|
|  |  |  | //    await RequestWmsTask(conveyorLine, command, childDeviceCode, ProtocalDetailValue); | 
|---|
|  |  |  | //} | 
|---|
|  |  |  | //else if ((conveyorLine.DeviceCode == "1001" && childDeviceCode == "1068")) | 
|---|
|  |  |  | //{ | 
|---|
|  |  |  | //    ConveyorLineOutFinish(conveyorLine, command, childDeviceCode, ProtocalDetailValue); | 
|---|
|  |  |  | //} | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | /// <summary> | 
|---|
|  |  |  | 
|---|
|  |  |  | { | 
|---|
|  |  |  | // 使用正则表达式匹配类似 -数字 的模式,并替换为空字符串 | 
|---|
|  |  |  | task.NextAddress = Regex.Replace(task.NextAddress, @"-(\d+)", ""); | 
|---|
|  |  |  | if (Convert.ToInt32(task.NextAddress) > 1999) | 
|---|
|  |  |  | { | 
|---|
|  |  |  | task.NextAddress = (Convert.ToInt32(task.NextAddress) - 1000).ToString(); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | var comm = _mapper.Map<ConveyorLineTaskCommand>(task); | 
|---|
|  |  |  | comm.InteractiveSignal = command.InteractiveSignal; | 
|---|
|  |  |  | return comm; | 
|---|
|  |  |  | 
|---|
|  |  |  |  | 
|---|
|  |  |  | if (_taskRepository.QueryFirst(x => x.PalletCode == taskDTO.PalletCode) != null) | 
|---|
|  |  |  | { | 
|---|
|  |  |  | if (_taskRepository.QueryFirst(x => x.PalletCode == command.Barcode) != null) | 
|---|
|  |  |  | { | 
|---|
|  |  |  |  | 
|---|
|  |  |  | var taskExecuting = _taskRepository.QueryFirst(x => x.PalletCode == command.Barcode && (x.TaskState == (int)TaskOutStatusEnum.Line_OutExecuting|| x.TaskState == (int)TaskOutStatusEnum.SC_OutFinish)); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | if (taskExecuting != null) | 
|---|
|  |  |  | { | 
|---|
|  |  |  | taskExecuting.ExceptionMessage = "未接收到线体完成信号系统内部自动完成"; | 
|---|
|  |  |  | _taskService.Delete(taskExecuting); | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | ConsoleHelper.WriteErrorLine($"当前托盘存在任务:【{command.Barcode}】"); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | WriteInfo(conveyorLine.DeviceName, $"当前托盘存在任务{command.Barcode}"); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | } | 
|---|
|  |  |  | WriteInfo(conveyorLine.DeviceName, "当前托盘存在任务"); | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | var content = CreateAndSendTask(taskDTO); | 
|---|
|  |  |  | if (content.Status) | 
|---|
|  |  |  | { | 
|---|
|  |  |  | var task = _taskService.QueryConveyorLineTask(conveyorLine.DeviceCode, childDeviceCode); | 
|---|
|  |  |  | var task = _taskService.QueryConveyorLineTask(conveyorLine.DeviceCode, childDeviceCode, command.Barcode); | 
|---|
|  |  |  | if (task != null) | 
|---|
|  |  |  | { | 
|---|
|  |  |  | //var taskCommand = MapTaskCommand(task, command); | 
|---|
|  |  |  | 
|---|
|  |  |  | var taskCommand = MapTaskCommand(task, command); | 
|---|
|  |  |  | task.NextAddress = next; | 
|---|
|  |  |  |  | 
|---|
|  |  |  | ConsoleHelper.WriteWarningLine($"【{conveyorLine._deviceName}】任务号:【{command.TaskNum}】,托盘条码:【{command.Barcode}】已到达【{childDeviceCode}】请求扫码入库(空托盘),下一目标地址【{taskCommand.TargetAddress}】"); | 
|---|
|  |  |  | var log = $"【{conveyorLine._deviceName}】任务号:【{command.TaskNum}】,托盘条码:【{command.Barcode}】已到达【{childDeviceCode}】请求扫码入库(空托盘),下一目标地址【{taskCommand.TargetAddress}】"; | 
|---|
|  |  |  | ConsoleHelper.WriteWarningLine(log); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | _noticeService.Logs(userTokenIds, new { conveyorLine.DeviceName, log = log, time = DateTime.Now.ToString("G"), color = "red" }); | 
|---|
|  |  |  | WriteInfo(conveyorLine.DeviceName, log); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | conveyorLine.SendCommand(taskCommand, childDeviceCode); | 
|---|
|  |  |  | ConveyorLineSendFinish(conveyorLine, childDeviceCode, ProtocalDetailValue, true); | 
|---|
|  |  |  | 
|---|
|  |  |  | var task = _taskService.QueryBarCodeConveyorLineTask(command.Barcode, childDeviceCode); | 
|---|
|  |  |  | if (task != null) | 
|---|
|  |  |  | { | 
|---|
|  |  |  | //var taskCommand = MapTaskCommand(task, command); | 
|---|
|  |  |  | var next = task.NextAddress; | 
|---|
|  |  |  | var taskCommand = MapTaskCommand(task, command); | 
|---|
|  |  |  | task.NextAddress = next; | 
|---|
|  |  |  | var value = _sys_ConfigService.GetByConfigKey(CateGoryConst.CONFIG_SYS_InStation, SysConfigKeyConst.JZNGInBoundStation).ConfigValue; | 
|---|
|  |  |  | var valueList = value.Split(',').ToList(); | 
|---|
|  |  |  | if (valueList.Contains(task.SourceAddress)) | 
|---|
|  |  |  | { | 
|---|
|  |  |  | conveyorLine.SetValue(ConveyorLineDBName.WriteConveyorLineTargetAddress, "1000", childDeviceCode); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | ConsoleHelper.WriteWarningLine($"【{conveyorLine._deviceName}】任务号:【{command.TaskNum}】,托盘条码:【{command.Barcode}】已到达【{childDeviceCode}】请求扫码入库(是胖),下一目标地址【{taskCommand.TargetAddress}】"); | 
|---|
|  |  |  | var log = $"【{conveyorLine._deviceName}】任务号:【{task.TaskNum}】,托盘条码:【{task.PalletCode}】已到达【{childDeviceCode}】请求扫码入库(实盘),下一目标地址【{1000}】"; | 
|---|
|  |  |  | ConsoleHelper.WriteWarningLine(log); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | conveyorLine.SendCommand(taskCommand, childDeviceCode); | 
|---|
|  |  |  | ConveyorLineSendFinish(conveyorLine, childDeviceCode, ProtocalDetailValue, true); | 
|---|
|  |  |  | _taskService.UpdateTaskStatusToNext(task); | 
|---|
|  |  |  | _noticeService.Logs(userTokenIds, new { conveyorLine.DeviceName, log = log, time = DateTime.Now.ToString("G"), color = "red" }); | 
|---|
|  |  |  | WriteInfo(conveyorLine.DeviceName, log); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | ConveyorLineSendFinish(conveyorLine, childDeviceCode, ProtocalDetailValue, true); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | else if (task.TargetAddress == "1020-1" || task.TargetAddress == "1049-8") | 
|---|
|  |  |  | { | 
|---|
|  |  |  | var next = task.NextAddress; | 
|---|
|  |  |  | var taskCommand = MapTaskCommand(task, command); | 
|---|
|  |  |  | task.NextAddress = next; | 
|---|
|  |  |  |  | 
|---|
|  |  |  | var log = $"【{conveyorLine._deviceName}】任务号:【{command.TaskNum}】,托盘条码:【{command.Barcode}】已到达【{childDeviceCode}】请求扫码入库(实盘),下一目标地址【{taskCommand.TargetAddress}】"; | 
|---|
|  |  |  | ConsoleHelper.WriteWarningLine(log); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | _noticeService.Logs(userTokenIds, new { conveyorLine.DeviceName, log = log, time = DateTime.Now.ToString("G"), color = "red" }); | 
|---|
|  |  |  | WriteInfo(conveyorLine.DeviceName, log); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | conveyorLine.SendCommand(taskCommand, childDeviceCode); | 
|---|
|  |  |  | ConveyorLineSendFinish(conveyorLine, childDeviceCode, ProtocalDetailValue, true); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | var taskHty = task.Adapt<Dt_Task_Hty>(); | 
|---|
|  |  |  | _task_HtyRepository.AddData(taskHty); | 
|---|
|  |  |  | _taskService.DeleteData(task); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | else | 
|---|
|  |  |  | { | 
|---|
|  |  |  | var next = task.NextAddress; | 
|---|
|  |  |  | var taskCommand = MapTaskCommand(task, command); | 
|---|
|  |  |  | task.NextAddress = next; | 
|---|
|  |  |  |  | 
|---|
|  |  |  | var log = $"【{conveyorLine._deviceName}】任务号:【{command.TaskNum}】,托盘条码:【{command.Barcode}】已到达【{childDeviceCode}】请求扫码入库(实盘),下一目标地址【{taskCommand.TargetAddress}】"; | 
|---|
|  |  |  | ConsoleHelper.WriteWarningLine(log); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | _noticeService.Logs(userTokenIds, new { conveyorLine.DeviceName, log = log, time = DateTime.Now.ToString("G"), color = "red" }); | 
|---|
|  |  |  | WriteInfo(conveyorLine.DeviceName, log); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | conveyorLine.SendCommand(taskCommand, childDeviceCode); | 
|---|
|  |  |  | ConveyorLineSendFinish(conveyorLine, childDeviceCode, ProtocalDetailValue, true); | 
|---|
|  |  |  | _taskService.UpdateTaskStatusToNext(task); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | else | 
|---|
|  |  |  | WriteInfo(conveyorLine.DeviceName, content.Message); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|