Sic.Framework/MECF.Framework.RT.Equipment.../Unit/IoLift3.cs

202 lines
5.9 KiB
C#
Raw Normal View History

2023-04-13 11:51:03 +08:00
using System.Xml;
using Aitex.Core.RT.DataCenter;
using Aitex.Core.RT.Event;
using Aitex.Core.RT.IOCore;
using Aitex.Core.RT.Log;
using Aitex.Core.RT.OperationCenter;
using Aitex.Core.Util;
namespace Aitex.Core.RT.Device.Unit
{
public enum LiftStateEnum
{
Unknown,
Up,
Down,
Error,
}
public class IoLift3 : BaseDevice, IDevice
{
public LiftStateEnum State
{
get
{
if (_diUp.Value && _diDown.Value)
return LiftStateEnum.Error;
if (_diUp.Value && !_diDown.Value)
return LiftStateEnum.Up;
if (!_diUp.Value && _diDown.Value)
return LiftStateEnum.Down;
return LiftStateEnum.Unknown;
}
}
enum DeviceState
{
Idle,
MovingUp,
MovingDown,
Error,
}
private DIAccessor _diUp;
private DIAccessor _diDown;
private DOAccessor _doUp;
private DOAccessor _doDown;
private DeviceState _state = DeviceState.Idle;
private DeviceTimer _timer = new DeviceTimer();
private int _scTimeout = 10;
public bool IsUp { get { return !_diDown.Value && _diUp.Value; } }
public bool IsDown { get { return _diDown.Value && !_diUp.Value; } }
public IoLift3(string module, XmlElement node, string ioModule = "")
{
base.Module = string.IsNullOrEmpty(node.GetAttribute("module")) ? module : node.GetAttribute("module");
base.Name = node.GetAttribute("id");
base.Display = node.GetAttribute("display");
base.DeviceID = node.GetAttribute("schematicId");
_diUp = ParseDiNode("diUp", node, ioModule);
_diDown = ParseDiNode("diDown", node, ioModule);
_doUp = ParseDoNode("doUp", node, ioModule);
_doDown = ParseDoNode("doDown", node, ioModule);
//_scTimeout = ParseScNode("scTimeout", node);
}
public bool Initialize()
{
_state = DeviceState.Idle;
DATA.Subscribe($"{Module}.{Name}.UpFeedback", () => _diUp.Value);
DATA.Subscribe($"{Module}.{Name}.DownFeedback", () => _diDown.Value);
DATA.Subscribe($"{Module}.{Name}.State", () => State.ToString());
OP.Subscribe($"{Module}.{Name}.MoveUp", (function, args) =>
{
return MoveUp(out string reason);
});
OP.Subscribe($"{Module}.{Name}.MoveDown", (function, args) =>
{
return MoveDown(out string reason);
});
return true;
}
public void Monitor()
{
switch (_state)
{
case DeviceState.MovingUp:
if (IsUp)
{
_timer.Stop();
if (!_doUp.SetValue(false, out string reason))
{
LOG.Error($"{Module} reset DO failed, {reason}");
}
_state = DeviceState.Idle;
}
else if (_timer.IsTimeout())
{
_timer.Stop();
if (!_doUp.SetValue(false, out string reason))
{
LOG.Error($"{Module} reset DO failed, {reason}");
}
EV.PostAlarmLog(Module, $"{Module} {Name} Can not move up in {_scTimeout} seconds");
_state = DeviceState.Error;
}
break;
case DeviceState.MovingDown:
if (IsDown)
{
_timer.Stop();
if (!_doDown.SetValue(false, out string reason))
{
LOG.Error($"{Module} reset DO failed, {reason}");
}
_state = DeviceState.Idle;
}
else if (_timer.IsTimeout())
{
_timer.Stop();
if (!_doDown.SetValue(false, out string reason))
{
LOG.Error($"{Module} reset DO failed, {reason}");
}
EV.PostAlarmLog(Module, $"{Module} {Name} Can not move down in {_scTimeout} seconds");
_state = DeviceState.Error;
}
break;
default:
break;
}
}
public void Terminate()
{
_doDown.SetValue(false, out _);
_doUp.SetValue(false, out _);
}
public bool Move(bool up, out string reason)
{
if (up)
return MoveUp(out reason);
return MoveDown(out reason);
}
public bool MoveUp(out string reason)
{
if (!_doDown.SetValue(false, out reason) || !_doUp.SetValue(true, out reason))
{
_doDown.SetValue(false, out _);
_doUp.SetValue(false, out _);
return false;
}
_timer.Start(_scTimeout * 1000);
_state = DeviceState.MovingUp;
return true;
}
public bool MoveDown(out string reason)
{
if (!_doUp.SetValue(false, out reason) || !_doDown.SetValue(true, out reason))
{
_doDown.SetValue(false, out _);
_doUp.SetValue(false, out _);
return false;
}
_timer.Start(_scTimeout * 1000);
_state = DeviceState.MovingDown;
return true;
}
public void Reset()
{
}
}
}