|
|
|
|
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
|
|
|
|
|
{
|
|
|
|
|
/// <summary>
|
|
|
|
|
/// 钣金任务列表
|
|
|
|
|
/// </summary>
|
|
|
|
|
public class AucamTaskService : IAucamTaskService
|
|
|
|
|
{
|
|
|
|
|
#region 钣金任务
|
|
|
|
|
/// <summary>
|
|
|
|
|
/// 实时任务信息-每日产量
|
|
|
|
|
/// </summary>
|
|
|
|
|
public delegate Task SmEverDayDelegate();
|
|
|
|
|
public static event SmEverDayDelegate SmEverDayDelegateEvent;
|
|
|
|
|
|
|
|
|
|
/// <summary>
|
|
|
|
|
/// 实时任务信息-展示
|
|
|
|
|
/// </summary>
|
|
|
|
|
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 钣金——前板
|
|
|
|
|
/// <summary>
|
|
|
|
|
/// 钣金——前板
|
|
|
|
|
/// </summary>
|
|
|
|
|
/// <param name="sender"></param>
|
|
|
|
|
/// <param name="e"></param>
|
|
|
|
|
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 钣金——后板
|
|
|
|
|
/// <summary>
|
|
|
|
|
/// 钣金——后板
|
|
|
|
|
/// </summary>
|
|
|
|
|
/// <param name="sender"></param>
|
|
|
|
|
/// <param name="e"></param>
|
|
|
|
|
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 钣金—实时任务列表
|
|
|
|
|
/// <summary>
|
|
|
|
|
/// 钣金—实时任务列表
|
|
|
|
|
/// </summary>
|
|
|
|
|
/// <param name="sender"></param>
|
|
|
|
|
/// <param name="e"></param>
|
|
|
|
|
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
|
|
|
|
|
}
|
|
|
|
|
}
|