using iWareCc.Cache.Entity;
|
using iWareCc.DecomposeTask.Entity;
|
using iWareCc.Properties;
|
using iWareCc.Srm.Entity;
|
using iWareCommon.Common.Entity;
|
using iWareCommon.Common.EnumType;
|
using iWareCommon.Utils;
|
using iWareDataCore.DEV.EnumType;
|
using System;
|
using System.Collections.Generic;
|
using System.Linq;
|
using System.Text;
|
using System.Threading;
|
using System.Threading.Tasks;
|
|
namespace iWareCc.FinishStackerTask.Chain
|
{
|
public class 等待堆垛机完成任务 : IHandler
|
{
|
/// <summary>
|
/// 该节点的下一个节点
|
/// </summary>
|
private IHandler nextHandler = null;
|
public IHandler NextHandler
|
{
|
set { nextHandler = value; }
|
}
|
|
private StackerEntity Stacker;
|
|
/// <summary>
|
/// 任务容器
|
/// </summary>
|
private PartTaskContainer DecompositionTaskContainer;
|
|
|
public 等待堆垛机完成任务(StackerEntity stacker, PartTaskContainer decompositionTaskContainer)
|
{
|
this.Stacker = stacker;
|
this.DecompositionTaskContainer = decompositionTaskContainer;
|
}
|
|
|
public void Handle()
|
{
|
try
|
{
|
if (Stacker.WTaskNo != DecompositionTaskContainer.PartTask.Id)
|
{
|
LogTextHelper.WriteLine(Resources.LogDir + @"/完成堆垛机任务/" + Stacker.Equipment.EquipName, "等待堆垛机完成任务WCSId={0},STAKERID={1}:{2}", DecompositionTaskContainer.PartTask.Id, Stacker.WTaskNo, "任务号不匹配");
|
return;
|
}
|
|
|
if (Stacker.TaskFinish < 1)
|
{
|
LogTextHelper.WriteLine(Resources.LogDir + @"/完成堆垛机任务/" + Stacker.Equipment.EquipName, "等待堆垛机完成任务:{0}", "任务执行中...");
|
return;
|
}
|
|
var flag1 = CacheEntity.OpcWcfServiceClient.WriteValue(Stacker.OpcWriteItems.TaskNo, (int)EYesOrNo.否);
|
|
while (Stacker.State != (int)ESrmState.堆垛机空闲)
|
{
|
Thread.Sleep(1000);
|
}
|
if (!flag1)
|
{
|
LogTextHelper.WriteLine(Resources.LogDir + @"/完成堆垛机任务/" + Stacker.Equipment.EquipName, "等待堆垛机完成任务:{0}", "发送OPC失败");
|
return;
|
}
|
|
LogTextHelper.WriteLine(Resources.LogDir + @"/完成堆垛机任务/" + Stacker.Equipment.EquipName, "等待堆垛机完成任务:{0}", "任务已完成");
|
|
if (nextHandler != null)
|
{
|
nextHandler.Handle();
|
}
|
}
|
catch (Exception ex)
|
{
|
LogTextHelper.WriteLog(Resources.LogDir, this.ToString(), "Handle", ex.Message);
|
}
|
}
|
}
|
}
|