From 8c9ea4fb36c8d1c2b2d2d517d63504b90f530f8c Mon Sep 17 00:00:00 2001 From: 刘磊 <1161824510@qq.com> Date: 星期四, 19 十二月 2024 15:41:19 +0800 Subject: [PATCH] 同步,火警出库 --- Code Management/WCS/WIDESEAWCS_Server/WIDESEAWCS_Tasks/ConveyorLineJob/CommonConveyorLineJob.cs | 68 ++++++++++++++++++++++----------- 1 files changed, 45 insertions(+), 23 deletions(-) diff --git a/Code Management/WCS/WIDESEAWCS_Server/WIDESEAWCS_Tasks/ConveyorLineJob/CommonConveyorLineJob.cs b/Code Management/WCS/WIDESEAWCS_Server/WIDESEAWCS_Tasks/ConveyorLineJob/CommonConveyorLineJob.cs index 5530d5b..bc4f8f6 100644 --- a/Code Management/WCS/WIDESEAWCS_Server/WIDESEAWCS_Tasks/ConveyorLineJob/CommonConveyorLineJob.cs +++ b/Code Management/WCS/WIDESEAWCS_Server/WIDESEAWCS_Tasks/ConveyorLineJob/CommonConveyorLineJob.cs @@ -58,7 +58,7 @@ _noticeService = noticeService; } - public async Task Execute(IJobExecutionContext context) + public Task Execute(IJobExecutionContext context) { try { @@ -68,7 +68,7 @@ List<string> childDeviceCodes = _routerService.QueryAllPositions(conveyorLine.DeviceCode); foreach (string childDeviceCode in childDeviceCodes) { - await ProcessDeviceAsync(conveyorLine, childDeviceCode); + ProcessDeviceAsync(conveyorLine, childDeviceCode); } List<Dt_StationManager> stationManagers = _stationManagerService.GetAllStationByDeviceCode(conveyorLine.DeviceCode); @@ -99,9 +99,10 @@ { Console.Out.WriteLine(nameof(CommonConveyorLineJob) + ":" + ex.ToString()); } + return Task.CompletedTask; } - private async Task ProcessDeviceAsync(CommonConveyorLine conveyorLine, string childDeviceCode) + private void ProcessDeviceAsync(CommonConveyorLine conveyorLine, string childDeviceCode) { ConveyorLineTaskCommand command = conveyorLine.ReadCustomer<ConveyorLineTaskCommand>(childDeviceCode); ConveyorLineTaskCommandWrite commandWrite = conveyorLine.ReadCustomer<ConveyorLineTaskCommandWrite>(childDeviceCode, "DeviceCommand"); @@ -121,22 +122,32 @@ MethodInfo? method = GetType().GetMethod(item.ProtocolDetailType); if (method != null) { - command.InteractiveSignal = commandWrite.WriteInteractiveSignal; - method.Invoke(this, new object[] { conveyorLine, command, childDeviceCode, item.ProtocalDetailValue.ObjToInt() }); + var numRead = item.ProtocalDetailValue.ObjToInt(); + var numWrite = item.ProtocalDetailValue.ObjToInt() + 1; + ConsoleHelper.WriteWarningLine($"銆恵conveyorLine.DeviceName}銆戙�恵childDeviceCode}銆戙�恵numRead.ToString()}銆戜綅杈撻�佺嚎璇诲彇淇″彿锛氥�恵structs[item.ProtocalDetailValue.ObjToInt()]}銆� 銆恵numWrite}銆戜綅WCS鍐欏叆淇″彿锛氥�恵structs[item.ProtocalDetailValue.ObjToInt() + 1]}銆�"); + if (structs[item.ProtocalDetailValue.ObjToInt() + 1] != structs[item.ProtocalDetailValue.ObjToInt()]) + { + command.InteractiveSignal = commandWrite.WriteInteractiveSignal; + method.Invoke(this, new object[] { conveyorLine, command, childDeviceCode, item.ProtocalDetailValue.ObjToInt() }); + } } } else { - DeviceProDTO? devicePro = conveyorLine.DeviceProDTOs.Where(x => x.DeviceProParamType == nameof(DeviceCommand) && x.DeviceChildCode == childDeviceCode).OrderBy(x => x.DeviceProOffset).FirstOrDefault(); - string[] x = devicePro.DeviceProAddress.Split('.'); - x[x.Length - 1] = (item.ProtocalDetailValue.ObjToInt() + 1).ToString(); - string DeviceProAddress = string.Join(".", x); - var writeRead = conveyorLine.Communicator.Read<bool>(DeviceProAddress); - if (writeRead) - { - conveyorLine.Communicator.Write(DeviceProAddress, false); - //ConveyorLineSendFinish(conveyorLine, childDeviceCode, item.ProtocalDetailValue.ObjToInt(), false); - } + + + ConveyorLineSendFinish(conveyorLine, childDeviceCode, item.ProtocalDetailValue.ObjToInt(), false); + + //DeviceProDTO? devicePro = conveyorLine.DeviceProDTOs.Where(x => x.DeviceProParamType == nameof(DeviceCommand) && x.DeviceChildCode == childDeviceCode).OrderBy(x => x.DeviceProOffset).FirstOrDefault(); + //string[] x = devicePro.DeviceProAddress.Split('.'); + //x[x.Length - 1] = (item.ProtocalDetailValue.ObjToInt() + 1).ToString(); + //string DeviceProAddress = string.Join(".", x); + //var writeRead = conveyorLine.Communicator.Read<bool>(DeviceProAddress); + //if (writeRead) + //{ + // conveyorLine.Communicator.Write(DeviceProAddress, false); + // //ConveyorLineSendFinish(conveyorLine, childDeviceCode, item.ProtocalDetailValue.ObjToInt(), false); + //} } } } @@ -192,11 +203,10 @@ object obj = new { - childDeviceCode, command, commandWrite }; - _noticeService.LineData(userIds?.FirstOrDefault(), userTokenIds, new { conveyorLine.DeviceName, data = obj }); + _noticeService.LineData(userIds?.FirstOrDefault(), userTokenIds, new { conveyorLine.DeviceName, childDeviceCode, data = obj }); #endregion 璋冪敤浜嬩欢鎬荤嚎閫氱煡鍓嶇 } @@ -218,11 +228,21 @@ ConsoleHelper.WriteWarningLine($"銆恵conveyorLine._deviceName}銆戜换鍔″彿锛氥�恵command.TaskNum}銆�,鎵樼洏鏉$爜锛氥�恵command.Barcode}銆戝凡鍒拌揪銆恵childDeviceCode}銆戣姹傛壂鐮佸叆搴�"); var task = _taskService.QueryBarCodeConveyorLineTask(command.Barcode, childDeviceCode); - HandleTaskOut(conveyorLine, command, childDeviceCode, ProtocalDetailValue, task); - - if (task == null && command.Barcode != "NoRead" && command.Barcode.IsNotEmptyOrNull()) + if (task != null) { - HandleNewTask(conveyorLine, command, childDeviceCode, ProtocalDetailValue); + if (task.TaskType == (int)TaskOutboundTypeEnum.OutTray || task.TaskType == (int)TaskOutboundTypeEnum.Outbound) + { + HandleTaskOut(conveyorLine, command, childDeviceCode, ProtocalDetailValue, task); + } + } + else + { + if (task == null && command.Barcode != "NoRead" && command.Barcode.IsNotEmptyOrNull()) + { + task = _taskService.QueryBarcodeTask(command.Barcode, childDeviceCode); + if (task == null) + HandleNewTask(conveyorLine, command, childDeviceCode, ProtocalDetailValue); + } } } catch (Exception ex) @@ -274,6 +294,7 @@ /// <param name="ProtocalDetailValue">绾夸綋褰撳墠bool璇诲彇鍋忕Щ鍦板潃</param> public void ConveyorLineInFinish(CommonConveyorLine conveyorLine, ConveyorLineTaskCommand command, string childDeviceCode, int ProtocalDetailValue) { + ConsoleHelper.WriteWarningLine($"銆恵conveyorLine._deviceName}銆戜换鍔″彿锛氥�恵command.TaskNum}銆�,鎵樼洏鏉$爜锛氥�恵command.Barcode}銆戝凡鍒拌揪銆恵childDeviceCode}銆戣緭閫佺嚎鍏ュ簱瀹屾垚"); var task = _taskService.QueryExecutingConveyorLineTask(command.TaskNum, childDeviceCode); if (task != null && task.TaskState != (int)TaskInStatusEnum.Line_InFinish) { @@ -318,9 +339,10 @@ public void RequestOutbound(CommonConveyorLine conveyorLine, ConveyorLineTaskCommand command, string childDeviceCode, int ProtocalDetailValue) { var task = _taskService.QueryConveyorLineTask(conveyorLine.DeviceCode, childDeviceCode); + ConsoleHelper.WriteSuccessLine($"銆恵conveyorLine._deviceName}銆戜换鍔″彿锛氥�恵command.TaskNum}銆�,鎵樼洏鏉$爜锛氥�恵command.Barcode}銆戝凡鍒拌揪銆恵childDeviceCode}銆戣緭閫佺嚎璇锋眰鍑哄簱,task{task.ToJsonString()}"); if (task != null) { - if (command.Barcode == task.PalletCode) + //if (command.Barcode == task.PalletCode) { //task.NextAddress = task.NextAddress.Replace("-1", ""); //ConveyorLineTaskCommand taskCommand = _mapper.Map<ConveyorLineTaskCommand>(task); @@ -470,7 +492,7 @@ var tasks = _taskRepository.QueryData(x => x.TaskType == (int)taskType && x.TargetAddress == childDeviceCode); if (tasks.Count < index) { - ConsoleHelper.WriteErrorLine($"銆恵childDeviceCode}銆戣姹傘�恵taskType.ToString()}銆戜换鍔�,宸叉湁銆恵taskType.ToString()}銆戜换鍔°�恵tasks.Count}銆�,鏈�澶氭嫢鏈夈�恵index - 1}銆�"); + //ConsoleHelper.WriteErrorLine($"銆恵childDeviceCode}銆戣姹傘�恵taskType.ToString()}銆戜换鍔�,宸叉湁銆恵taskType.ToString()}銆戜换鍔°�恵tasks.Count}銆�,鏈�澶氭嫢鏈夈�恵index - 1}銆�"); #region 璋冪敤WMS鑾峰彇鍑哄簱浠诲姟 -- Gitblit v1.9.3