using CFX; using HslCommunication; using Sln.Iot.CFX.CFXBusiness; using Sln.Iot.CFX.CFXConnect; using Sln.Iot.CFX.Event; using Sln.Iot.PLC; using Sln.Iot.Repository.service; using Sln.Iot.Serilog; using System; using System.Collections.Generic; using System.Linq; using System.Security.Cryptography; using System.Text; using System.Threading.Tasks; using static System.Runtime.CompilerServices.RuntimeHelpers; namespace Sln.Iot.Business { public class RFID02Business { private Timer _timer; private readonly PLCConnect _plc = PLCConnect.Instance; private readonly SerilogHelper _log = SerilogHelper.Instance; private TrayBindingService trayBindingService = TrayBindingService.Instance; private OvenPlcDataService ovenPlcDataService = OvenPlcDataService.Instance; private UnitsProcessPLCDataGetBusiness unitsProcessPLCDataGetBusiness = UnitsProcessPLCDataGetBusiness.Instance; private CFXUnitProcessedDataGet cfxUnitProcessedDataGet = CFXUnitProcessedDataGet.Instance; private WorkStageStartedEvent workStageStartedEvent = new WorkStageStartedEvent(); private WorkStageCompletedEvent workStageCompletedEvent = new WorkStageCompletedEvent(); private WorkCompletedEvent workCompletedEvent = new WorkCompletedEvent(); private UnitsDepartedEvent unitsDepartedEvent = new UnitsDepartedEvent(); private UnitsArrivedEvent unitsArrivedEvent = new UnitsArrivedEvent(); private WorkStartedEvent workStartedEvent = new WorkStartedEvent(); private UnitsProcessedEvent unitsProcessedEvent = new UnitsProcessedEvent(); private CFXConnectOven ConnectOven = CFXConnectOven.Instance; private CFXConnectVacuum ConnectVacuum = CFXConnectVacuum.Instance; public RFID02Business() { _timer = new Timer(TimerCallback, null, 0, 2000); } /// /// RFID02胶机1真空箱内数据处理流程 /// /// public void TimerCallback(object? state) { try { // 定时任务逻辑 //读取信号 OperateResult signalRes = _plc.ReadInt16(_plc.PLC23, "D800"); //成功验证 if (signalRes.IsSuccess) { short signalValue = signalRes.Content; //如果有读取信号 if (signalValue == 2001) { //读取托盘码 OperateResult trayBytesResult = _plc.ReadBytes(_plc.PLC23, "D5000", 10); //成功验证 if (trayBytesResult.IsSuccess) { //转换托盘码 string traycode = Encoding.ASCII.GetString(trayBytesResult.Content); traycode = traycode.Replace("?", ""); traycode = traycode.Replace("\0", ""); _log.Info($"托盘到达-RFID02-托盘号-[{traycode}]"); //记录胶机1真空箱内到达时间 trayBindingService.UpDateTime(DateTime.Now.ToString(), traycode, "2"); bool res = false; //写入完成信号 res = _plc.PlcWrite(_plc.PLC23, "D800", 2002, DataTypeEnum.UInt16).IsSuccess; if (!res) { _log.Error("胶机1真空箱内写入完成信号异常"); } //取出work唯一guid(tid) string stid = trayBindingService.TidGet(traycode); if (!Guid.TryParse(stid, out Guid tid)) { tid = Guid.Parse("11111111-1111-4111-9111-111111111111"); _log.Error("找不到对应的托盘信息,赋值默认GUID"); } string[] prodcode = trayBindingService.ProdCodeGet(traycode); //CFX Task.Run(() => { //真空箱工段完成事件 ConnectVacuum.PublishEvent(new CFXEnvelope(workStageCompletedEvent.Handle(tid, "Vacuum", 1))); _log.Info($"真空箱工段完成 ID:{tid}"); ConnectVacuum.PublishEvent(new CFXEnvelope(workCompletedEvent.Handle(tid, traycode, prodcode))); _log.Info($"工作完成事件发布 ID:{tid}"); ConnectVacuum.PublishEvent(new CFXEnvelope(unitsDepartedEvent.Handle(traycode, prodcode))); _log.Info($"单元离站 ID:{tid}"); //单元抵达事件 ConnectOven.PublishEvent(new CFXEnvelope(unitsArrivedEvent.Handle(traycode, prodcode))); //工作开始事件 ConnectOven.PublishEvent(new CFXEnvelope(workStartedEvent.Handle(tid, traycode, prodcode))); _log.Info($"工作开始,ID:{tid}"); //真空箱工段开启 ConnectOven.PublishEvent(new CFXEnvelope(workStageStartedEvent.Handle(tid, "Oven", 1))); _log.Info($"真空箱工段开始 ID:{tid}"); }); //CFX } else { _log.Error($"PLC读取失败,原因:{trayBytesResult.Message}"); } //流程完成 } else if (signalValue == 2003) { //读取托盘码 OperateResult trayBytesResult = _plc.ReadBytes(_plc.PLC23, "D5000", 10); if (trayBytesResult.IsSuccess) { string traycode = Encoding.ASCII.GetString(trayBytesResult.Content); traycode = traycode.Replace("?", ""); traycode = traycode.Replace("\0", ""); //计算预热炉停留时长: time2 - time1 string time2 = trayBindingService.GetTimeByTrayCode(traycode, "2"); string time1 = trayBindingService.GetTimeByTrayCode(traycode, "1"); ushort spanSecond = 0; if (!string.IsNullOrEmpty(time2) && !string.IsNullOrEmpty(time1)) { TimeSpan span = Convert.ToDateTime(time2) - Convert.ToDateTime(time1); spanSecond = (ushort)span.TotalSeconds; _log.Info($"预热炉停留时长: [{spanSecond}]秒"); } bool res = _plc.PlcWrite(_plc.PLC23, "D810", spanSecond, DataTypeEnum.UInt16).IsSuccess; if (!res) { _log.Error("RFID02 发送预热炉停留时长 PLC写入异常"); } res = false; //写入完成信号 res = _plc.PlcWrite(_plc.PLC23, "D800", 2004, DataTypeEnum.UInt16).IsSuccess; if (!res) { _log.Error("RFID02 发送真空箱停留时长 PLC写入完成信号异常"); } Task.Run(() => { //取出work唯一guid(tid) string stid = trayBindingService.TidGet(traycode); if (!Guid.TryParse(stid, out Guid tid)) { tid = Guid.Parse("11111111-1111-4111-9111-111111111111"); _log.Error("找不到对应的托盘信息,赋值默认GUID"); } var data = unitsProcessPLCDataGetBusiness.VacuumPlcDataGet(); _log.Info($"真空灌胶机数据 — " + $"推胶速度设定值:{data.GluePushSpeedSetValue} " + $"胶量设定值:[{data.GlueAmountSetValue1},{data.GlueAmountSetValue2},{data.GlueAmountSetValue3},{data.GlueAmountSetValue4},{data.GlueAmountSetValue5},{data.GlueAmountSetValue6},{data.GlueAmountSetValue7},{data.GlueAmountSetValue8},{data.GlueAmountSetValue9},{data.GlueAmountSetValue10}] " + $"真空度设定值:{data.VacuumDegreeSetValue} 保压时长设定值:{data.PressureHoldTimeSetValue} " + $"真空箱启用设定值:{data.VacuumIsUseSetValue} 总胶量设定值:{data.TotalGlueAmountSetValue} " + $"A泵压力实际值:{data.PumpAPressureActValue} B泵压力实际值:{data.PumpBPressureActValue} " + $"灌胶真空度实际值:{data.VacuumDegreeActValue} 配方数据:{data.FormulaData}"); ConnectVacuum.PublishEvent(new CFXEnvelope(unitsProcessedEvent.Handle(tid, cfxUnitProcessedDataGet.ProcessDataGetVacuum(data)))); }); } else { _log.Error($"PLC读取失败,原因:{trayBytesResult.Message}"); } } } else { _log.Error($"胶机1真空箱内PLC读取信号异常,原因:{signalRes.Message}"); } } catch (Exception ex) { _log.Error("RFID02业务出现异常", ex); } } } }