using Aitex.Core.RT.Device;
using Aitex.Core.RT.Log;
using Aitex.Core.RT.Routine;
using Aitex.Core.RT.SCCore;
using MECF.Framework.Common.Routine;
using CyberX8_Core;
using CyberX8_RT.Devices.Facilities;
using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Threading.Tasks;
namespace CyberX8_RT.Devices.Dryer
{
public class DryerBlowerHighRoutine : RoutineBase, IRoutine
{
///
/// step
///
private enum DryerBlowerHighStep
{
HighOn,
Delay,
CheckExhaustPressure,
ReturnLow,
End
}
#region 内部变量
private bool _bypass = false;
private double _minimumPressure = 0;
private int _delayTime = 1000;
private DryerDevice _device;
private SystemFacilities _facilities;
private bool _backLow = false;
#endregion
///
/// 构造函数
///
///
public DryerBlowerHighRoutine(string module,DryerDevice device) : base(module)
{
_device = device;
}
///
/// 中止
///
public void Abort()
{
Runner.Stop("Manual Abort");
}
///
/// 监控
///
///
public RState Monitor()
{
Runner.Run(DryerBlowerHighStep.HighOn, _device.BlowerHighOn, () => { return _device.CommonData.BlowerHigh; }, _delay_1s)
.Delay(DryerBlowerHighStep.Delay, _delayTime)
.Run(DryerBlowerHighStep.CheckExhaustPressure, CheckExhaustPressure, _delay_1ms)
.Run(DryerBlowerHighStep.ReturnLow, ReturnLow, _delay_1ms)
.End(DryerBlowerHighStep.End, NullFun, _delay_1ms);
return Runner.Status;
}
///
/// 检验Pressure
///
///
private bool CheckExhaustPressure()
{
if (_bypass)
{
return true;
}
else
{
if(_device.CommonData.ExhaustPressure>_minimumPressure)
{
_backLow = true;
LOG.WriteLog(eEvent.ERR_DRYER, Module, $"Current ExhaustPressure{_device.CommonData.ExhaustPressure} is large than {_minimumPressure}");
}
else
{
_backLow = false;
}
return true;
}
}
///
/// Return Low
///
///
private bool ReturnLow()
{
if (_bypass)
{
return true;
}
else
{
if(_backLow)
{
_device.BlowerLowOn();
}
return true;
}
}
///
/// 启动
///
///
///
public RState Start(params object[] objs)
{
_bypass=(bool)objs[0];
if(_bypass)
{
_delayTime = 1;
}
_facilities = DEVICE.GetDevice("System.Facilities");
if(!CheckPreCondition())
{
return RState.End;
}
_backLow = false;
_minimumPressure = SC.GetValue("Dryer.MinimumPressure");
return Runner.Start(Module, "Start Dryer Blower Hight");
}
///
/// 检验前置条件
///
///
private bool CheckPreCondition()
{
if(!_device.CommonData.PowerControl)
{
LOG.WriteLog(eEvent.ERR_DRYER, Module, "Power Control is off");
return false;
}
var result = _facilities.CheckExhaustResult();
if(!result.result)
{
LOG.WriteLog(eEvent.ERR_DRYER, Module, result.reason);
return false;
}
if(_device.FacilityCommonLimitData.IsWarning || _device.FacilityCommonLimitData.IsError)
{
LOG.WriteLog(eEvent.ERR_DRYER, Module, "Exhuast Pressure is Abnormal");
return false;
}
return true;
}
}
}