using Admin.Core.Common; using Admin.Core.IService; using Admin.Core.Model; using Admin.Core.Model.Model_New; using Aucma.Core.PLc; using log4net; using System.Timers; namespace Aucma.Core.Tasks { /// /// 钣金任务列表 /// public class AucamTaskService : IAucamTaskService { #region 钣金任务 /// /// 实时任务信息-每日产量 /// public delegate Task SmEverDayDelegate(); public static event SmEverDayDelegate SmEverDayDelegateEvent; /// /// 实时任务信息-展示 /// public delegate Task SmShowDelegate(ExecutePlanInfo info); public static event SmShowDelegate SmShowDelegateEvent; #endregion private static readonly log4net.ILog log = LogManager.GetLogger(typeof(AucamTaskService)); private readonly ISmTaskExecutionServices _smTaskExecutionServices; private readonly ISMProductionCompletionRecordServices _smProductionCompletionRecordServices; public AucamTaskService(ISmTaskExecutionServices smTaskExecutionServices, ISMProductionCompletionRecordServices smProductionCompletionRecordServices, IBoxFoamDataServices oldBoxFoamDataServices) { _smTaskExecutionServices= smTaskExecutionServices; _smProductionCompletionRecordServices = smProductionCompletionRecordServices; } System.Timers.Timer timer1 = new System.Timers.Timer(2000); System.Timers.Timer timer2 = new System.Timers.Timer(2000); System.Timers.Timer timer3 = new System.Timers.Timer(2000); bool qFlay=true;//前板标识 bool hFlay = true;//后板标识 public void AucamTaskAsync() { timer1.Elapsed += new System.Timers.ElapsedEventHandler(Run1); //到达时间的时候执行事件; timer1.AutoReset = true;//设置是执行一次(false)还是一直执行(true); timer1.Enabled = true;//需要调用 timer.Start()或者timer.Enabled = true来启动它, timer1.Start();//timer.Start()的内部原理还是设置timer.Enabled = true; timer2.Elapsed += new System.Timers.ElapsedEventHandler(Run2); //到达时间的时候执行事件; timer2.AutoReset = true; timer2.Enabled = true; timer2.Start(); timer3.Elapsed += new System.Timers.ElapsedEventHandler(RealTimeTask); timer3.AutoReset = true; timer3.Enabled = true; timer3.Start(); } #region 钣金——前板 /// /// 钣金——前板 /// /// /// private void Run1(object? sender, ElapsedEventArgs e) { if (qFlay) { qFlay=false; //执行存盘操作 var obj = PlcHelper.melsecList.FirstOrDefault(d => d.EquipName.Equals("FrontPlatePlc")); if (obj.plc.IsConnected) { var val = obj.plc.ReadInt16("M110");//任务结束信号存盘 if (val == 1) { SmTaskExecution smTask = _smTaskExecutionServices.FirstAsync(d=>d.IsExec==1).Result; SMProductionCompletionRecord sm=new SMProductionCompletionRecord(); sm.SmPlanid = smTask.TaskCode; sm.SmProductcode = smTask.MaterialCode; sm.SmProductname = smTask.MaterialName; sm.SmProductiontype = 0; sm.SmProductivetime =DateTime.Now; int result = _smProductionCompletionRecordServices.AddAsync(sm).Result; if (result>0) { bool saveDb = obj.plc.WriteInt16("M111", "1");//存盘完成信号 if (saveDb) { Console.WriteLine("前板完成"); qFlay = true; //刷新计划数、小时数据、型号统计数据 Console.WriteLine("执行刷新任务执行界面"); Console.WriteLine("执行每日刷新界面"); Console.WriteLine("执行型号刷新界面"); Console.WriteLine("执行实时任务刷新界面"); } } else { qFlay = true; } } } } } #endregion #region 钣金——后板 /// /// 钣金——后板 /// /// /// private void Run2(object? sender, ElapsedEventArgs e) { if (hFlay) { hFlay = false; //执行存盘操作 var obj = PlcHelper.melsecList.FirstOrDefault(d => d.EquipName.Equals("RearPanelPLC")); if (obj.plc.IsConnected) { var val = obj.plc.ReadInt16("M101");//任务结束信号存盘 if (val == 1) { SmTaskExecution smTask = _smTaskExecutionServices.FirstAsync(d => d.IsExec == 1).Result; SMProductionCompletionRecord sm = new SMProductionCompletionRecord(); sm.SmPlanid = smTask.TaskCode; sm.SmProductcode = smTask.MaterialCode; sm.SmProductname = smTask.MaterialName; sm.SmProductiontype = 0; sm.SmProductivetime = DateTime.Now; int result = _smProductionCompletionRecordServices.AddAsync(sm).Result; if (result > 0) { bool saveDb = obj.plc.WriteInt16("M102", "1");//存盘完成信号 if (saveDb) { Console.WriteLine("后板完成"); hFlay = true; //刷新计划数、小时数据、型号统计数据 Console.WriteLine("执行刷新任务执行界面"); Console.WriteLine("执行每日刷新界面"); Console.WriteLine("执行型号刷新界面"); Console.WriteLine("执行实时任务刷新界面"); } } else { hFlay = true; } } } } } #endregion #region 钣金—实时任务列表 /// /// 钣金—实时任务列表 /// /// /// private void RealTimeTask(object? sender, ElapsedEventArgs e) { var execTask = _smTaskExecutionServices.FirstAsync(d => d.IsExec == 0&&d.TaskSort==d.TaskSort).Result; if (execTask.FrontPlateAmount == execTask.RearPanelAmount) { execTask.IsExec = 2; execTask.CompleteAmount = execTask.FrontPlateAmount; bool r= _smTaskExecutionServices.UpdateAsync(execTask).Result; if (r) { var obj = _smTaskExecutionServices.QueryAsync(d => d.IsExec == 0).Result; int maxId = obj.Max(d => d.TaskSort); var task = obj.SingleOrDefault(d => d.IsExec == 0 && d.TaskSort == maxId); if (task == null) return; task.IsExec=1; bool exec= _smTaskExecutionServices.UpdateAsync(task).Result; //执行刷新任务执行界面 Console.WriteLine("执行刷新任务执行界面"); Console.WriteLine("执行每日刷新界面"); Console.WriteLine("执行型号刷新界面"); Console.WriteLine("执行实时任务刷新界面"); } } Console.WriteLine("实时任务列表"); } #endregion #region 实施当日产量和型号统计 public void Run() { //SmEverDayDelegateEvent?.Invoke(); } #endregion #region 实时计划显示 public void RealTimePlanRun() { //var model = _taskExecutionServices.FirstAsync(d => d.ExecuteStatus == 2).Result; //SmShowDelegateEvent?.Invoke(model); } #endregion #region 任务完成 public void CompleteRun() { var obj = PlcHelper.melsecList.FirstOrDefault(d => d.EquipName.Equals("后板Plc")); if (obj == null) return; var val = obj.plc.ReadInt32("M100");//任务结束信号存盘 if (val == 1) { //1、存储当日完成记录表、计算节拍信息 //2、更新界面计划执行、当日产量、型号统计、计划列表 //3、更新日志记录 //4、更新数据统计列表 } } #endregion } }