From d79fcd9534d97f5bbb4edb66dbb925dea0479304 Mon Sep 17 00:00:00 2001 From: IPC-610 <IPC-610@DESKTOP-6LEOOS3> Date: 星期日, 22 九月 2024 15:06:34 +0800 Subject: [PATCH] ssd12313 --- Admin.NET/WCS.Application/PLC/PLCTaskAction.cs | 29 +++++++++++++++++++---------- 1 files changed, 19 insertions(+), 10 deletions(-) diff --git a/Admin.NET/WCS.Application/PLC/PLCTaskAction.cs b/Admin.NET/WCS.Application/PLC/PLCTaskAction.cs index 2137784..b2aca60 100644 --- a/Admin.NET/WCS.Application/PLC/PLCTaskAction.cs +++ b/Admin.NET/WCS.Application/PLC/PLCTaskAction.cs @@ -20,7 +20,6 @@ private static readonly ISqlSugarClient _db = SqlSugarSetup.ITenant.GetConnectionScope(SqlSugarConst.MainConfigId); private static readonly SysCacheService sysCacheService = App.GetRequiredService<SysCacheService>(); - private static readonly IHubContext<PlcHub, IPlcHub> _plcHubContext = App.GetService<IHubContext<PlcHub, IPlcHub>>(); private static readonly SysConfigService _sysConfigService = App.GetService<SysConfigService>(); private static List<WcsPlc> listPlc = new List<WcsPlc>(); @@ -79,7 +78,7 @@ var plc = new PLCUtil(modPlc); listPlcUtil.Add(plc); } - _plcHubContext.Clients.All.UpdateService(new PLCServiceModel() + HubUtil.UpdateService(new PLCServiceModel() { BoRunningState = boRunningState, BoOffline = boOffline, @@ -172,7 +171,7 @@ } } - Thread.Sleep(10000); + Thread.Sleep(1000); } catch (OperationCanceledException) { @@ -225,14 +224,14 @@ { //杩炴帴鐘舵�佸彉鏇� 閫氱煡鍓嶇 Console.WriteLine($"閫氱煡鍓嶇鍙樻洿{modPlc.Text} {modPlc.IsConn}"); - _plcHubContext.Clients.All.PublicPlcConn(modPlc); + HubUtil.PublicPlcConn(modPlc); } sysCacheService.Set("PLCCONN:" + modPlc.Id, modPlc); } else { sysCacheService.Set("PLCCONN:" + modPlc.Id, modPlc); - _plcHubContext.Clients.All.PublicPlcConn(modPlc); + HubUtil.PublicPlcConn(modPlc); } } Thread.Sleep(1000); @@ -331,7 +330,7 @@ listLog.Add(modLog); } _db.Insertable(listLog).ExecuteCommand(); - _plcHubContext.Clients.All.PublicAlarm(listPulish); + HubUtil.PublicAlarm(listPulish); } } catch (Exception ex) @@ -398,16 +397,26 @@ { var value = Convert.ToInt32(item.Value); var height = Math.Round(value / 790000d * 200).ToInt(); - if (modDevice.BoxHeight != height) + var modPosition = listPlcPosition.FirstOrDefault(s => s.DeviceId == modDevice.Id && s.Text == "鐩殑宸ヤ綅"); + string EndLocat = ""; + if (modPosition != null) { + var (result2, value2) = modPlcUtil.GetPlcDBValue(modPosition.PosType, modDevice.DbNumber, modPosition.PlcPos); + if (result2.IsSucceed) + EndLocat = Convert.ToString(value2); + } + if (modDevice.BoxHeight != height || modDevice.EndLocat != EndLocat) + { + modDevice.EndLocat = EndLocat; modDevice.BoxHeight = Math.Round(value / 790000d * 200).ToInt(); var modInfo = new PlcPositionInfo() { Type = modPlc.Type, StationNum = modDevice.StationNum, - BoxHeight = modDevice.BoxHeight + BoxHeight = modDevice.BoxHeight, + EndLocat = EndLocat, }; - _plcHubContext.Clients.All.PublicPosition(modInfo); + HubUtil.PublicPosition(modInfo); UpdatePosition(modInfo); } } @@ -420,7 +429,7 @@ modDevice.BoHaveItem = value; //涓嬪彂鐘舵�� var modInfo = new PlcPositionInfo() { Type = modPlc.Type, StationNum = modDevice.StationNum, BoHaveItem = value }; - _plcHubContext.Clients.All.PublicPosition(modInfo); + HubUtil.PublicPosition(modInfo); UpdatePosition(modInfo); } } -- Gitblit v1.8.0