|  |  |  | 
|---|
|  |  |  | using WIDESEAWCS_QuartzJob; | 
|---|
|  |  |  | using WIDESEAWCS_QuartzJob.DeviceBase; | 
|---|
|  |  |  | using WIDESEAWCS_QuartzJob.DTO; | 
|---|
|  |  |  | using WIDESEAWCS_QuartzJob.Models; | 
|---|
|  |  |  | using WIDESEAWCS_QuartzJob.Repository; | 
|---|
|  |  |  | using WIDESEAWCS_QuartzJob.Service; | 
|---|
|  |  |  | using WIDESEAWCS_SignalR; | 
|---|
|  |  |  | 
|---|
|  |  |  | CommonConveyorLine conveyorLine = (CommonConveyorLine)context.JobDetail.JobDataMap.Get("JobParams"); | 
|---|
|  |  |  | if (conveyorLine != null) | 
|---|
|  |  |  | { | 
|---|
|  |  |  | //ConsoleHelper.WriteColorLine("开始:" + DateTime.Now, ConsoleColor.Cyan); | 
|---|
|  |  |  | // 查询所有子设备的位置 | 
|---|
|  |  |  | List<string> childDeviceCodes = _routerService.QueryAllPositions(conveyorLine.DeviceCode); | 
|---|
|  |  |  | // 获取所有站点管理器 | 
|---|
|  |  |  | List<Dt_StationManager> stationManagers = _stationManagerService.GetAllStationByDeviceCode(conveyorLine.DeviceCode); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | // 并行处理每个子设备 | 
|---|
|  |  |  | var tasks = childDeviceCodes.Select(childDeviceCode => ProcessDeviceAsync(conveyorLine, childDeviceCode)).ToList(); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | // 并行处理每个站点管理器 | 
|---|
|  |  |  | tasks = stationManagers.Select(station => Task.Run(async () => | 
|---|
|  |  |  | { | 
|---|
|  |  |  | var (command, commandWrite) = ReadCommands(station, conveyorLine); | 
|---|
|  |  |  | if (command == null || commandWrite == null) | 
|---|
|  |  |  | { | 
|---|
|  |  |  | return; | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | IStationHandler handler = StationHandlerFactory.GetHandler(station.stationType, this); | 
|---|
|  |  |  | await handler.HandleStationAsync(conveyorLine, station, command, commandWrite); | 
|---|
|  |  |  | })).ToList(); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | #region | 
|---|
|  |  |  | //foreach (var station in stationManagers) | 
|---|
|  |  |  | //{ | 
|---|
|  |  |  | //    #region | 
|---|
|  |  |  | //    //tasks.Add(Task.Run(async () => | 
|---|
|  |  |  | //    //{ | 
|---|
|  |  |  | //    //    if (station.stationType == 11) | 
|---|
|  |  |  | //    //    { | 
|---|
|  |  |  | //    //        // 读取任务命令和设备命令 | 
|---|
|  |  |  | //    //        ConveyorLineTaskCommand command = conveyorLine.ReadCustomer<ConveyorLineTaskCommand>(station.stationChildCode); | 
|---|
|  |  |  | //    //        ConveyorLineTaskCommandWrite commandWrite = conveyorLine.ReadCustomer<ConveyorLineTaskCommandWrite>(station.stationChildCode, "DeviceCommand"); | 
|---|
|  |  |  | //    //        if (command != null && commandWrite != null) | 
|---|
|  |  |  | //    //        { | 
|---|
|  |  |  | //    //            // 将交互信号转换为布尔数组 | 
|---|
|  |  |  | //    //            var structs = BitConverter.GetBytes(commandWrite.WriteInteractiveSignal).Reverse().ToArray().ToBoolArray(); | 
|---|
|  |  |  | //    //            if (structs[0] == true) | 
|---|
|  |  |  | //    //            { | 
|---|
|  |  |  | //    //                // 输出警告信息 | 
|---|
|  |  |  | //    //                var log = $"【{conveyorLine.DeviceName}】任务号:【{command.TaskNum}】,托盘条码:【{command.Barcode}】已到达【{station.stationChildCode}】空托盘请求扫码入库"; | 
|---|
|  |  |  | //    //                ConsoleHelper.WriteWarningLine(log); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | //    //                await _noticeService.Logs(userTokenIds, new { conveyorLine.DeviceName, log = log, time = DateTime.Now.ToString("G"), color = "red" }); | 
|---|
|  |  |  | //    //                WriteInfo(conveyorLine.DeviceName, log); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | //    //                // 处理入库请求 | 
|---|
|  |  |  | //    //                NGRequestTaskInbound(conveyorLine, command, station, 0); | 
|---|
|  |  |  | //    //            } | 
|---|
|  |  |  | //    //            else | 
|---|
|  |  |  | //    //            { | 
|---|
|  |  |  | //    //                // 发送完成信号 | 
|---|
|  |  |  | //    //                ConveyorLineSendFinish(conveyorLine, station.stationChildCode, 0, false); | 
|---|
|  |  |  | //    //            } | 
|---|
|  |  |  | //    //        } | 
|---|
|  |  |  | //    //    } | 
|---|
|  |  |  | //    //    else if (station.stationType == 5) | 
|---|
|  |  |  | //    //    { | 
|---|
|  |  |  | //    //        // 读取任务命令和设备命令 | 
|---|
|  |  |  | //    //        ConveyorLineTaskCommand command = conveyorLine.ReadCustomer<ConveyorLineTaskCommand>(station.stationChildCode); | 
|---|
|  |  |  | //    //        ConveyorLineTaskCommandWrite commandWrite = conveyorLine.ReadCustomer<ConveyorLineTaskCommandWrite>(station.stationChildCode, "DeviceCommand"); | 
|---|
|  |  |  | //    //        if (command != null && commandWrite != null) | 
|---|
|  |  |  | //    //        { | 
|---|
|  |  |  | //    //            // 将交互信号转换为布尔数组 | 
|---|
|  |  |  | //    //            var structs = BitConverter.GetBytes(commandWrite.WriteInteractiveSignal).Reverse().ToArray().ToBoolArray(); | 
|---|
|  |  |  | //    //            if (structs[0] == true) | 
|---|
|  |  |  | //    //            { | 
|---|
|  |  |  | //    //                // 检查是否存在任务 | 
|---|
|  |  |  | //    //                if (_taskRepository.QueryData(x => x.SourceAddress == station.stationChildCode).Count() > 0) | 
|---|
|  |  |  | //    //                { | 
|---|
|  |  |  | //    //                    return; | 
|---|
|  |  |  | //    //                } | 
|---|
|  |  |  | //    //                // 输出警告信息 | 
|---|
|  |  |  | //    //                var log = $"【{conveyorLine.DeviceName}】任务号:【{command.TaskNum}】,托盘条码:【{command.Barcode}】已到达【{station.stationChildCode}】异常口请求扫码入库"; | 
|---|
|  |  |  | //    //                ConsoleHelper.WriteWarningLine(log); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | //    //                await _noticeService.Logs(userTokenIds, new { conveyorLine.DeviceName, log = log, time = DateTime.Now.ToString("G"), color = "red" }); | 
|---|
|  |  |  | //    //                WriteInfo(conveyorLine.DeviceName, log); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | //    //                // 处理新任务 | 
|---|
|  |  |  | //    //                await HandleNewTaskAsync(conveyorLine, command, station.stationChildCode, 0); | 
|---|
|  |  |  | //    //            } | 
|---|
|  |  |  | //    //            else | 
|---|
|  |  |  | //    //            { | 
|---|
|  |  |  | //    //                // 发送完成信号 | 
|---|
|  |  |  | //    //                ConveyorLineSendFinish(conveyorLine, station.stationChildCode, 0, false); | 
|---|
|  |  |  | //    //            } | 
|---|
|  |  |  | //    //        } | 
|---|
|  |  |  | //    //    } | 
|---|
|  |  |  | //    //})); | 
|---|
|  |  |  | //    #endregion | 
|---|
|  |  |  |  | 
|---|
|  |  |  | //    tasks.Add(Task.Run(async () => | 
|---|
|  |  |  | //    { | 
|---|
|  |  |  | //        var (command, commandWrite) = ReadCommands(station, conveyorLine); | 
|---|
|  |  |  | //        if (command == null || commandWrite == null) | 
|---|
|  |  |  | //        { | 
|---|
|  |  |  | //            return; | 
|---|
|  |  |  | //        } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | //        IStationHandler handler = StationHandlerFactory.GetHandler(station.stationType, this); | 
|---|
|  |  |  | //        await handler.HandleStationAsync(conveyorLine, station, command, commandWrite); | 
|---|
|  |  |  | //    })); | 
|---|
|  |  |  | //} | 
|---|
|  |  |  | #endregion | 
|---|
|  |  |  |  | 
|---|
|  |  |  | await Task.WhenAll(tasks); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | // 获取所有站点管理器 | 
|---|
|  |  |  | List<Dt_StationManager> stationManagers = _stationManagerService.GetAllStationByDeviceCode(conveyorLine.DeviceCode); | 
|---|
|  |  |  | foreach (var station in stationManagers) | 
|---|
|  |  |  | { | 
|---|
|  |  |  | if (station.stationType == 11) | 
|---|
|  |  |  | { | 
|---|
|  |  |  | // 读取任务命令和设备命令 | 
|---|
|  |  |  | ConveyorLineTaskCommand command = conveyorLine.ReadCustomer<ConveyorLineTaskCommand>(station.stationChildCode); | 
|---|
|  |  |  | ConveyorLineTaskCommandWrite commandWrite = conveyorLine.ReadCustomer<ConveyorLineTaskCommandWrite>(station.stationChildCode, "DeviceCommand"); | 
|---|
|  |  |  | if (command != null && commandWrite != null) | 
|---|
|  |  |  | { | 
|---|
|  |  |  | // 将交互信号转换为布尔数组 | 
|---|
|  |  |  | var structs = BitConverter.GetBytes(commandWrite.WriteInteractiveSignal).Reverse().ToArray().ToBoolArray(); | 
|---|
|  |  |  | if (structs[0] == true) | 
|---|
|  |  |  | { | 
|---|
|  |  |  | // 输出警告信息 | 
|---|
|  |  |  | ConsoleHelper.WriteWarningLine($"【{conveyorLine.DeviceName}】任务号:【{command.TaskNum}】,托盘条码:【{command.Barcode}】已到达【{station.stationChildCode}】空托盘请求扫码入库"); | 
|---|
|  |  |  | // 处理入库请求 | 
|---|
|  |  |  | NGRequestTaskInbound(conveyorLine, command, station, 0); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | else | 
|---|
|  |  |  | { | 
|---|
|  |  |  | // 发送完成信号 | 
|---|
|  |  |  | ConveyorLineSendFinish(conveyorLine, station.stationChildCode, 0, false); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | else if (station.stationType == 5) | 
|---|
|  |  |  | { | 
|---|
|  |  |  | // 读取任务命令和设备命令 | 
|---|
|  |  |  | ConveyorLineTaskCommand command = conveyorLine.ReadCustomer<ConveyorLineTaskCommand>(station.stationChildCode); | 
|---|
|  |  |  | ConveyorLineTaskCommandWrite commandWrite = conveyorLine.ReadCustomer<ConveyorLineTaskCommandWrite>(station.stationChildCode, "DeviceCommand"); | 
|---|
|  |  |  | if (command != null && commandWrite != null) | 
|---|
|  |  |  | { | 
|---|
|  |  |  | // 将交互信号转换为布尔数组 | 
|---|
|  |  |  | var structs = BitConverter.GetBytes(commandWrite.WriteInteractiveSignal).Reverse().ToArray().ToBoolArray(); | 
|---|
|  |  |  | if (structs[0] == true) | 
|---|
|  |  |  | { | 
|---|
|  |  |  | // 检查是否存在任务 | 
|---|
|  |  |  | if (_taskRepository.QueryData(x => x.SourceAddress == station.stationChildCode).Count() > 0) | 
|---|
|  |  |  | { | 
|---|
|  |  |  | return; | 
|---|
|  |  |  | } | 
|---|
|  |  |  | // 输出警告信息 | 
|---|
|  |  |  | ConsoleHelper.WriteWarningLine($"【{conveyorLine.DeviceName}】任务号:【{command.TaskNum}】,托盘条码:【{command.Barcode}】已到达【{station.stationChildCode}】异常口请求扫码入库"); | 
|---|
|  |  |  | // 处理新任务 | 
|---|
|  |  |  | await HandleNewTaskAsync(conveyorLine, command, station.stationChildCode, 0); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | else | 
|---|
|  |  |  | { | 
|---|
|  |  |  | // 发送完成信号 | 
|---|
|  |  |  | ConveyorLineSendFinish(conveyorLine, station.stationChildCode, 0, false); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | //ConsoleHelper.WriteColorLine("结束:" + DateTime.Now, ConsoleColor.Cyan); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | catch (Exception ex) | 
|---|
|  |  |  | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | // 查询平台信息 | 
|---|
|  |  |  | Platform platform = _platFormRepository.QueryFirst(x => x.PLCCode == conveyorLine.DeviceCode && x.PlatCode == childDeviceCode && x.Status == "Active"); | 
|---|
|  |  |  | Platform platform = _platFormRepository.QueryFirst(x => x.DeviceCode == conveyorLine.DeviceCode && x.PlatCode == childDeviceCode && x.Status == "Active"); | 
|---|
|  |  |  | if (platform != null && !string.IsNullOrEmpty(platform.Location)) | 
|---|
|  |  |  | { | 
|---|
|  |  |  | var strings = platform.Location.Split(',').ToList(); | 
|---|
|  |  |  | 
|---|
|  |  |  | try | 
|---|
|  |  |  | { | 
|---|
|  |  |  | // 输出警告信息,表示任务已到达子设备并请求扫码入库 | 
|---|
|  |  |  | var log = $"【{conveyorLine._deviceName}】任务号:【{command.TaskNum}】,托盘条码:【{command.Barcode}】已到达【{childDeviceCode}】请求扫码入库"; | 
|---|
|  |  |  | var log = $"时间:【{DateTime.Now}】【{conveyorLine._deviceName}】任务号:【{command.TaskNum}】,托盘条码:【{command.Barcode}】已到达【{childDeviceCode}】请求扫码入库"; | 
|---|
|  |  |  | ConsoleHelper.WriteWarningLine(log); | 
|---|
|  |  |  | // 发送通知 | 
|---|
|  |  |  | await _noticeService.Logs(userTokenIds, new { conveyorLine.DeviceName, log = log, time = DateTime.Now.ToString("G"), color = "red" }); | 
|---|
|  |  |  | 
|---|
|  |  |  | conveyorLine.SendCommand(taskCommand, childDeviceCode); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | // 输出警告信息,表示任务已到达子设备并请求扫码入库,下一目标地址 | 
|---|
|  |  |  | ConsoleHelper.WriteWarningLine($"【{conveyorLine._deviceName}】任务号:【{command.TaskNum}】,托盘条码:【{command.Barcode}】已到达【{childDeviceCode}】请求扫码入库,下一目标地址【{taskCommand.TargetAddress}】"); | 
|---|
|  |  |  | var logs = $"时间:【{DateTime.Now}】【{conveyorLine._deviceName}】任务号:【{command.TaskNum}】,托盘条码:【{command.Barcode}】已到达【{childDeviceCode}】请求扫码入库,下一目标地址【{taskCommand.TargetAddress}】"; | 
|---|
|  |  |  | ConsoleHelper.WriteWarningLine(logs); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | await _noticeService.Logs(userTokenIds, new { conveyorLine.DeviceName, log = logs, time = DateTime.Now.ToString("G"), color = "red" }); | 
|---|
|  |  |  | WriteInfo(conveyorLine.DeviceName, logs); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | // 发送任务完成通知 | 
|---|
|  |  |  | ConveyorLineSendFinish(conveyorLine, childDeviceCode, ProtocalDetailValue, true); | 
|---|
|  |  |  | 
|---|
|  |  |  | /// <param name="childDeviceCode">子设备编号</param> | 
|---|
|  |  |  | public void RequestInNextAddress(CommonConveyorLine conveyorLine, ConveyorLineTaskCommand command, string childDeviceCode) | 
|---|
|  |  |  | { | 
|---|
|  |  |  | ConsoleHelper.WriteWarningLine($"【{conveyorLine._deviceName}】任务号:【{command.TaskNum}】,托盘条码:【{command.Barcode}】已到达【{childDeviceCode}】请求入库下一地址"); | 
|---|
|  |  |  | Dt_Task task = _taskService.QueryExecutingConveyorLineTask(command.TaskNum, childDeviceCode); | 
|---|
|  |  |  | var log = $"时间:【{DateTime.Now}】【{conveyorLine._deviceName}】任务号:【{command.TaskNum}】,托盘条码:【{command.Barcode}】已到达【{childDeviceCode}】请求入库下一地址"; | 
|---|
|  |  |  | ConsoleHelper.WriteWarningLine(log); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | _noticeService.Logs(userTokenIds, new { conveyorLine.DeviceName, log = log, time = DateTime.Now.ToString("G"), color = "red" }); | 
|---|
|  |  |  | WriteInfo(conveyorLine.DeviceName, log); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | Dt_Task task = _taskService.QueryExecutingConveyorLineTask(command.TaskNum, childDeviceCode, command.Barcode); | 
|---|
|  |  |  | if (task != null) | 
|---|
|  |  |  | { | 
|---|
|  |  |  | if (command.Barcode == task.PalletCode) | 
|---|
|  |  |  | 
|---|
|  |  |  | var taskCommand = MapTaskCommand(newTask, command); | 
|---|
|  |  |  | newTask.NextAddress = next; | 
|---|
|  |  |  |  | 
|---|
|  |  |  | ConsoleHelper.WriteWarningLine($"【{conveyorLine._deviceName}】任务号:【{command.TaskNum}】,托盘条码:【{command.Barcode}】已到达【{childDeviceCode}】请求入库下一地址,下一目标地址【{taskCommand.TargetAddress}】"); | 
|---|
|  |  |  | var logs = $"【{conveyorLine._deviceName}】任务号:【{command.TaskNum}】,托盘条码:【{command.Barcode}】已到达【{childDeviceCode}】请求入库下一地址,下一目标地址【{taskCommand.TargetAddress}】"; | 
|---|
|  |  |  | ConsoleHelper.WriteWarningLine(logs); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | _noticeService.Logs(userTokenIds, new { conveyorLine.DeviceName, log = logs, time = DateTime.Now.ToString("G"), color = "red" }); | 
|---|
|  |  |  | WriteInfo(conveyorLine.DeviceName, logs); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | conveyorLine.SendCommand(taskCommand, childDeviceCode); | 
|---|
|  |  |  | _taskService.UpdateData(newTask); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | 
|---|
|  |  |  | { | 
|---|
|  |  |  | try | 
|---|
|  |  |  | { | 
|---|
|  |  |  | ConsoleHelper.WriteWarningLine($"【{conveyorLine._deviceName}】任务号:【{command.TaskNum}】,托盘条码:【{command.Barcode}】已到达【{childDeviceCode}】输送线入库完成"); | 
|---|
|  |  |  | var task = _taskService.QueryExecutingConveyorLineTask(command.TaskNum, childDeviceCode); | 
|---|
|  |  |  | var log = $"时间:【{DateTime.Now}】【{conveyorLine._deviceName}】任务号:【{command.TaskNum}】,托盘条码:【{command.Barcode}】已到达【{childDeviceCode}】输送线入库完成"; | 
|---|
|  |  |  | ConsoleHelper.WriteWarningLine(log); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | _noticeService.Logs(userTokenIds, new { conveyorLine.DeviceName, log = log, time = DateTime.Now.ToString("G"), color = "red" }); | 
|---|
|  |  |  | WriteInfo(conveyorLine.DeviceName, log); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | var task = _taskService.QueryExecutingConveyorLineTask(command.TaskNum, childDeviceCode, command.Barcode); | 
|---|
|  |  |  | if (task != null && task.TaskState != (int)TaskInStatusEnum.Line_InFinish) | 
|---|
|  |  |  | { | 
|---|
|  |  |  | if (command.Barcode == task.PalletCode && childDeviceCode == task.NextAddress) | 
|---|
|  |  |  | { | 
|---|
|  |  |  | conveyorLine.SetValue(ConveyorLineDBName.WriteConveyorLineTargetAddress, "1000", childDeviceCode); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | ConsoleHelper.WriteWarningLine($"【{conveyorLine._deviceName}】任务号:【{command.TaskNum}】,托盘条码:【{command.Barcode}】已到达【{childDeviceCode}】输送线入库完成,下一目标地址【等待分配货位,并写入1000】"); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | ConveyorLineSendFinish(conveyorLine, childDeviceCode, ProtocalDetailValue, true); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | if (task.TaskType == (int)TaskInboundTypeEnum.InNG) | 
|---|
|  |  |  | { | 
|---|
|  |  |  | int nextStatus = task.TaskState.GetNextNotCompletedStatus<TaskInStatusEnum>(); | 
|---|
|  |  |  | 
|---|
|  |  |  | task.ModifyDate = DateTime.Now; | 
|---|
|  |  |  | task.Modifier = "System"; | 
|---|
|  |  |  | _taskRepository.UpdateData(task); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | conveyorLine.SetValue(ConveyorLineDBName.WriteConveyorLineTargetAddress, "1000", childDeviceCode); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | var logs = $"【{conveyorLine._deviceName}】任务号:【{command.TaskNum}】,托盘条码:【{command.Barcode}】已到达【{childDeviceCode}】输送线入库完成,下一目标地址【等待分配货位,并写入1000】"; | 
|---|
|  |  |  | ConsoleHelper.WriteWarningLine(logs); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | _noticeService.Logs(userTokenIds, new { conveyorLine.DeviceName, log = logs, time = DateTime.Now.ToString("G"), color = "red" }); | 
|---|
|  |  |  | WriteInfo(conveyorLine.DeviceName, logs); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | ConveyorLineSendFinish(conveyorLine, childDeviceCode, ProtocalDetailValue, true); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | else | 
|---|
|  |  |  | { | 
|---|
|  |  |  | WebResponseContent content = _taskService.UpdateTaskStatusToNext(task); | 
|---|
|  |  |  | WriteInfo(conveyorLine.DeviceName, content.ToJsonString()); | 
|---|
|  |  |  | if (!content.Status) | 
|---|
|  |  |  | { | 
|---|
|  |  |  | ConsoleHelper.WriteWarningLine($"【{conveyorLine._deviceName}】任务号:【{command.TaskNum}】,托盘条码:【{command.Barcode}】已到达【{childDeviceCode}】输送线入库完成,任务执行失败{JsonConvert.SerializeObject(content)}"); | 
|---|
|  |  |  | return; | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | conveyorLine.SetValue(ConveyorLineDBName.WriteConveyorLineTargetAddress, "1000", childDeviceCode); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | var logs = $"【{conveyorLine._deviceName}】任务号:【{command.TaskNum}】,托盘条码:【{command.Barcode}】已到达【{childDeviceCode}】输送线入库完成,下一目标地址【等待分配货位,并写入1000】"; | 
|---|
|  |  |  | ConsoleHelper.WriteWarningLine(logs); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | _noticeService.Logs(userTokenIds, new { conveyorLine.DeviceName, log = logs, time = DateTime.Now.ToString("G"), color = "red" }); | 
|---|
|  |  |  | WriteInfo(conveyorLine.DeviceName, logs); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | ConveyorLineSendFinish(conveyorLine, childDeviceCode, ProtocalDetailValue, true); | 
|---|
|  |  |  | Console.Out.WriteLine(content.ToJsonString()); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | 
|---|
|  |  |  | var task = _taskService.QueryConveyorLineTask(conveyorLine.DeviceCode, childDeviceCode); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | // 输出成功信息,包括输送线名称、任务号、托盘条码和子设备代码,以及任务信息 | 
|---|
|  |  |  | ConsoleHelper.WriteSuccessLine($"【{conveyorLine._deviceName}】任务号:【{command.TaskNum}】,托盘条码:【{command.Barcode}】已到达【{childDeviceCode}】输送线请求出库,task{task.ToJsonString()}"); | 
|---|
|  |  |  | var logs = $"时间:【{DateTime.Now}】【{conveyorLine._deviceName}】任务号:【{command.TaskNum}】,托盘条码:【{command.Barcode}】已到达【{childDeviceCode}】输送线请求出库,task{task.ToJsonString()}"; | 
|---|
|  |  |  | ConsoleHelper.WriteSuccessLine(logs); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | _noticeService.Logs(userTokenIds, new { conveyorLine.DeviceName, log = logs, time = DateTime.Now.ToString("G"), color = "red" }); | 
|---|
|  |  |  | WriteInfo(conveyorLine.DeviceName, logs); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | // 如果任务不为空,则执行以下操作 | 
|---|
|  |  |  | if (task != null) | 
|---|
|  |  |  | 
|---|
|  |  |  | task.NextAddress = next; | 
|---|
|  |  |  |  | 
|---|
|  |  |  | // 输出成功信息,包括输送线名称、任务号、托盘条码、子设备代码和下一目标地址 | 
|---|
|  |  |  | ConsoleHelper.WriteSuccessLine($"【{conveyorLine._deviceName}】任务号:【{command.TaskNum}】,托盘条码:【{command.Barcode}】已到达【{childDeviceCode}】输送线请求出库,下一目标地址【{taskCommand.TargetAddress}】"); | 
|---|
|  |  |  | var log = $"【{conveyorLine._deviceName}】任务号:【{command.TaskNum}】,托盘条码:【{command.Barcode}】已到达【{childDeviceCode}】输送线请求出库,下一目标地址【{taskCommand.TargetAddress}】"; | 
|---|
|  |  |  | ConsoleHelper.WriteSuccessLine(log); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | _noticeService.Logs(userTokenIds, new { conveyorLine.DeviceName, log = log, time = DateTime.Now.ToString("G"), color = "red" }); | 
|---|
|  |  |  | WriteInfo(conveyorLine.DeviceName, log); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | // 向输送线发送命令 | 
|---|
|  |  |  | conveyorLine.SendCommand(taskCommand, childDeviceCode); | 
|---|
|  |  |  | 
|---|
|  |  |  | _taskService.UpdateTaskStatusToNext(task); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | // 如果任务的目标地址是"1020-1",则再次更新任务状态到下一个状态 | 
|---|
|  |  |  | if (task.TargetAddress == "1020-1") | 
|---|
|  |  |  | if (task.TargetAddress == "1020-1"|| task.TargetAddress == "1049-8") | 
|---|
|  |  |  | { | 
|---|
|  |  |  | _taskService.UpdateTaskStatusToNext(task); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | 
|---|
|  |  |  | public void RequestOutNextAddress(CommonConveyorLine conveyorLine, ConveyorLineTaskCommand command, string childDeviceCode, int ProtocalDetailValue) | 
|---|
|  |  |  | { | 
|---|
|  |  |  | // 打印成功日志,显示当前设备名称、任务号、托盘条码以及请求出库下一地址的子设备代码 | 
|---|
|  |  |  | ConsoleHelper.WriteSuccessLine($"【{conveyorLine._deviceName}】任务号:【{command.TaskNum}】,托盘条码:【{command.Barcode}】已到达【{childDeviceCode}】输送线请求出库下一地址"); | 
|---|
|  |  |  | var log = $"【{conveyorLine._deviceName}】任务号:【{command.TaskNum}】,托盘条码:【{command.Barcode}】已到达【{childDeviceCode}】输送线请求出库下一地址"; | 
|---|
|  |  |  | ConsoleHelper.WriteSuccessLine(log); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | _noticeService.Logs(userTokenIds, new { conveyorLine.DeviceName, log = log, time = DateTime.Now.ToString("G"), color = "red" }); | 
|---|
|  |  |  | WriteInfo(conveyorLine.DeviceName, log); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | // 查询正在执行的输送线任务,根据任务号和子设备代码获取任务信息 | 
|---|
|  |  |  | Dt_Task task = _taskService.QueryExecutingConveyorLineTask(command.TaskNum, childDeviceCode); | 
|---|
|  |  |  | Dt_Task task = _taskService.QueryExecutingConveyorLineTask(command.TaskNum, childDeviceCode, command.Barcode); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | // 如果任务存在 | 
|---|
|  |  |  | if (task != null) | 
|---|
|  |  |  | 
|---|
|  |  |  | newTask.NextAddress = next; | 
|---|
|  |  |  |  | 
|---|
|  |  |  | // 打印成功日志,显示当前设备名称、任务号、托盘条码、子设备代码以及下一目标地址 | 
|---|
|  |  |  | ConsoleHelper.WriteSuccessLine($"【{conveyorLine._deviceName}】任务号:【{command.TaskNum}】,托盘条码:【{command.Barcode}】已到达【{childDeviceCode}】输送线请求出库下一地址,下一目标地址【{taskCommand.TargetAddress}】"); | 
|---|
|  |  |  | var logs = $"【{conveyorLine._deviceName}】任务号:【{command.TaskNum}】,托盘条码:【{command.Barcode}】已到达【{childDeviceCode}】输送线请求出库下一地址,下一目标地址【{taskCommand.TargetAddress}】"; | 
|---|
|  |  |  | ConsoleHelper.WriteSuccessLine(logs); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | _noticeService.Logs(userTokenIds, new { conveyorLine.DeviceName, log = logs, time = DateTime.Now.ToString("G"), color = "red" }); | 
|---|
|  |  |  | WriteInfo(conveyorLine.DeviceName, logs); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | // 发送任务命令到子设备 | 
|---|
|  |  |  | conveyorLine.SendCommand(taskCommand, childDeviceCode); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | // 标记输送线发送任务完成 | 
|---|
|  |  |  | ConveyorLineSendFinish(conveyorLine, childDeviceCode, ProtocalDetailValue, true); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | _taskService.UpdateData(newTask); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | 
|---|
|  |  |  | try | 
|---|
|  |  |  | { | 
|---|
|  |  |  | // 打印成功信息,表示托盘已到达指定输送线并完成出库 | 
|---|
|  |  |  | ConsoleHelper.WriteSuccessLine($"【{conveyorLine.DeviceName}】任务号:【{command.TaskNum}】,托盘条码:【{command.Barcode}】已到达【{childDeviceCode}】输送线出库完成"); | 
|---|
|  |  |  | var logs = $"【{conveyorLine.DeviceName}】任务号:【{command.TaskNum}】,托盘条码:【{command.Barcode}】已到达【{childDeviceCode}】输送线出库完成"; | 
|---|
|  |  |  | ConsoleHelper.WriteSuccessLine(logs); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | _noticeService.Logs(userTokenIds, new { conveyorLine.DeviceName, log = logs, time = DateTime.Now.ToString("G"), color = "red" }); | 
|---|
|  |  |  | WriteInfo(conveyorLine.DeviceName, logs); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | // 查询正在执行的输送线任务 | 
|---|
|  |  |  | var task = _taskService.QueryExecutingConveyorLineTask(command.TaskNum, childDeviceCode); | 
|---|
|  |  |  | var task = _taskService.QueryExecutingConveyorLineTask(command.TaskNum, childDeviceCode, command.Barcode); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | // 如果任务存在 | 
|---|
|  |  |  | if (task != null) | 
|---|
|  |  |  | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | // 打印成功信息,表示托盘已到达指定输送线并完成出库,下一目标地址已确定 | 
|---|
|  |  |  | ConsoleHelper.WriteSuccessLine($"【{conveyorLine.DeviceName}】任务号:【{command.TaskNum}】,托盘条码:【{command.Barcode}】已到达【{childDeviceCode}】输送线出库完成,下一目标地址【{taskCommand.TargetAddress}】"); | 
|---|
|  |  |  | var log = $"【{conveyorLine.DeviceName}】任务号:【{command.TaskNum}】,托盘条码:【{command.Barcode}】已到达【{childDeviceCode}】输送线出库完成,下一目标地址【{taskCommand.TargetAddress}】"; | 
|---|
|  |  |  | ConsoleHelper.WriteSuccessLine(log); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | _noticeService.Logs(userTokenIds, new { conveyorLine.DeviceName, log = log, time = DateTime.Now.ToString("G"), color = "red" }); | 
|---|
|  |  |  | WriteInfo(conveyorLine.DeviceName, log); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | // 发送命令到输送线 | 
|---|
|  |  |  | conveyorLine.SendCommand(taskCommand, childDeviceCode); | 
|---|
|  |  |  | // 完成输送线发送 | 
|---|
|  |  |  | 
|---|
|  |  |  | // 查询目标地址的容量 | 
|---|
|  |  |  | var NGAddress = _platFormRepository.QueryFirst(x => x.PlatCode == task.TargetAddress).Capacity; | 
|---|
|  |  |  | // 打印成功信息,表示托盘已到达指定输送线并完成出库,下一目标地址已确定 | 
|---|
|  |  |  | ConsoleHelper.WriteSuccessLine($"【{conveyorLine.DeviceName}】任务号:【{command.TaskNum}】,托盘条码:【{command.Barcode}】已到达【{childDeviceCode}】输送线出库完成,下一目标地址【{NGAddress}】"); | 
|---|
|  |  |  | var log = $"【{conveyorLine.DeviceName}】任务号:【{command.TaskNum}】,托盘条码:【{command.Barcode}】已到达【{childDeviceCode}】输送线出库完成,下一目标地址【{NGAddress}】"; | 
|---|
|  |  |  | ConsoleHelper.WriteSuccessLine(log); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | _noticeService.Logs(userTokenIds, new { conveyorLine.DeviceName, log = log, time = DateTime.Now.ToString("G"), color = "red" }); | 
|---|
|  |  |  | WriteInfo(conveyorLine.DeviceName, log); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | // 设置输送线的目标地址为NG地址 | 
|---|
|  |  |  | conveyorLine.SetValue(ConveyorLineDBName.WriteConveyorLineTargetAddress, NGAddress, childDeviceCode); | 
|---|
|  |  |  | // 完成输送线发送 | 
|---|
|  |  |  | 
|---|
|  |  |  | // 将修改后的数组x重新拼接成字符串,作为新的DeviceProAddress | 
|---|
|  |  |  | string DeviceProAddress = string.Join(".", x); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | // 使用conveyorLine的Communicator对象的Write方法,将value写入新的DeviceProAddress地址 | 
|---|
|  |  |  | conveyorLine.Communicator.Write(DeviceProAddress, value); | 
|---|
|  |  |  | var writeBool = conveyorLine.Communicator.Read<bool>(DeviceProAddress); | 
|---|
|  |  |  | if (writeBool != value) | 
|---|
|  |  |  | { | 
|---|
|  |  |  | // 使用conveyorLine的Communicator对象的Write方法,将value写入新的DeviceProAddress地址 | 
|---|
|  |  |  | conveyorLine.Communicator.Write(DeviceProAddress, value); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | #region 检测空盘实盘任务 | 
|---|
|  |  |  | 
|---|
|  |  |  | } | 
|---|
|  |  |  | var wmsIpAddress = wmsBase + requestTrayOutTask; | 
|---|
|  |  |  |  | 
|---|
|  |  |  | var device = _deviceInfoRepository.QueryData(x => x.DeviceStatus == "1" && x.DeviceRemark == platform.Id.ToString()); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | List<Dt_DeviceInfo> device; | 
|---|
|  |  |  | if (platform.Roadway != null) | 
|---|
|  |  |  | { | 
|---|
|  |  |  | List<string> strings = platform.Roadway.Split(',').ToList(); | 
|---|
|  |  |  | device = _deviceInfoRepository.QueryData(x => x.DeviceStatus == "1" && strings.Contains(x.DeviceCode)); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | else | 
|---|
|  |  |  | { | 
|---|
|  |  |  | device = _deviceInfoRepository.QueryData(x => x.DeviceStatus == "1"); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | var deviceCode = device.Select(x => x.DeviceCode).ToList(); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | // 发送HTTP POST请求获取任务数据 | 
|---|
|  |  |  | var result = await HttpHelper.PostAsync(wmsIpAddress, new { position = childDeviceCode, tag = (int)taskType, areaCdoe = platform.Stacker, AreaCdoes = deviceCode, platform.ProductionLine }.ToJsonString()); | 
|---|
|  |  |  | // 解析返回的JSON数据 | 
|---|
|  |  |  | WebResponseContent content = JsonConvert.DeserializeObject<WebResponseContent>(result); | 
|---|
|  |  |  |  | 
|---|
|  |  |  |  | 
|---|
|  |  |  | Console.WriteLine($"{JsonConvert.SerializeObject(content)}呼叫成功"); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | // 检查返回状态,如果失败则返回 | 
|---|
|  |  |  | if (!content.Status) | 
|---|
|  |  |  | 
|---|
|  |  |  | taskDTO = JsonConvert.DeserializeObject<WMSTaskDTO>(content.Data.ToString()); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | #endregion 调用WMS获取出库任务 | 
|---|
|  |  |  |  | 
|---|
|  |  |  |  | 
|---|
|  |  |  | // 创建并发送任务 | 
|---|
|  |  |  | CreateAndSendTask(taskDTO); | 
|---|
|  |  |  | 
|---|
|  |  |  | var content = _taskService.ReceiveWMSTask(new List<WMSTaskDTO> { taskDTO }); | 
|---|
|  |  |  | if (content.Status) | 
|---|
|  |  |  | { | 
|---|
|  |  |  | Console.WriteLine($"{taskDTO.TaskType}呼叫成功"); | 
|---|
|  |  |  | Console.WriteLine($"{taskDTO.TargetAddress}呼叫成功"); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | return content; | 
|---|
|  |  |  | } | 
|---|
|  |  |  | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | #endregion 设备NG口入库 | 
|---|
|  |  |  |  | 
|---|
|  |  |  | public async Task LogAndWarn(string deviceName, string log, string color = "red") | 
|---|
|  |  |  | { | 
|---|
|  |  |  | ConsoleHelper.WriteWarningLine(log); | 
|---|
|  |  |  | await _noticeService.Logs(userTokenIds, new { deviceName, log = log, time = DateTime.Now.ToString("G"), color = color }); | 
|---|
|  |  |  | WriteInfo(deviceName, log); | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | private (ConveyorLineTaskCommand, ConveyorLineTaskCommandWrite) ReadCommands(Dt_StationManager station, CommonConveyorLine conveyorLine) | 
|---|
|  |  |  | { | 
|---|
|  |  |  | ConveyorLineTaskCommand command = conveyorLine.ReadCustomer<ConveyorLineTaskCommand>(station.stationChildCode); | 
|---|
|  |  |  | ConveyorLineTaskCommandWrite commandWrite = conveyorLine.ReadCustomer<ConveyorLineTaskCommandWrite>(station.stationChildCode, "DeviceCommand"); | 
|---|
|  |  |  | return (command, commandWrite); | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|