using Aitex.Core.RT.Log;
using Aitex.Core.RT.Routine;
using MECF.Framework.Common.CommonData.PUF;
using MECF.Framework.Common.Routine;
using CyberX8_Core;
using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Threading.Tasks;
namespace CyberX8_RT.Devices.AXIS.Galil
{
public class GalilHomeRoutine : RoutineBase, IRoutine
{
private enum HomeStep
{
HomingAcceleration,
HomingDeceleration,
HomingSpeed,
SetHomeModel,
StartMotion,
Delay,
CheckHomingEnd,
DP,
End
}
#region 常量
private const int HOME_STOP_CODE = 10;
#endregion
#region 内部变量
private JetAxisBase _axis;
private int _timeout = 5000;
private int _homingAcceleration = 0;
private int _homingDeceleration = 0;
private int _homingSpeed = 0;
#endregion
public GalilHomeRoutine(string module,JetAxisBase axis) : base(module)
{
_axis = axis;
}
public void Abort()
{
Runner.Stop("Manual Abort");
}
public RState Monitor()
{
Runner.Run(HomeStep.HomingAcceleration, () => { return _axis.WriteAcceleration(_homingAcceleration); }, _delay_1ms)
.Run(HomeStep.HomingDeceleration, () => { return _axis.WriteDeceleration(_homingDeceleration); }, _delay_1ms)
.Run(HomeStep.HomingSpeed, () => { return _axis.WriteSpeed(_homingSpeed); }, _delay_1ms)
.Run(HomeStep.SetHomeModel, () => { return _axis.WriteHomeAxisCommand(); }, _delay_1ms)
.Run(HomeStep.StartMotion, () => { return _axis.WriteStartMotion(); }, _delay_1ms)
.Delay(HomeStep.Delay,500)
.WaitWithStopCondition(HomeStep.CheckHomingEnd, () => {
return _axis.MotionData.StopCode == HOME_STOP_CODE&&!_axis.IsRun; },CheckErrorOrWarning,_timeout)
.Run(HomeStep.DP, () => { return _axis.WriteDPZero(); }, _delay_1ms)
.End(HomeStep.End,NullFun,100);
return Runner.Status;
}
///
/// 检验是否出错或告警
///
///
private bool CheckErrorOrWarning()
{
//byte stopCode = _axis.MotionData.StopCode;
//if (stopCode != 0 && stopCode != HOME_STOP_CODE)
//{
// LOG.WriteLog(eEvent.ERR_AXIS, Module, $"axis home stopcode is {stopCode}");
// return true;
//}
return false;
}
public RState Start(params object[] objs)
{
_timeout = (int)objs[0];
_homingAcceleration = (int)objs[1];
_homingDeceleration = (int)objs[2];
_homingSpeed = (int)objs[3];
return Runner.Start(Module, "Home");
}
}
}