using Aitex.Core.RT.Device; using Aitex.Core.RT.Routine; using Aitex.Core.Util; using MECF.Framework.Common.RecipeCenter; using MECF.Framework.Common.Routine; using MECF.Framework.Common.Utilities; using PunkHPX8_Core; using PunkHPX8_RT.Devices.AXIS; using PunkHPX8_RT.Devices.PlatingCell; using System; using System.Collections.Generic; using System.Linq; using System.Text; using System.Threading.Tasks; namespace PunkHPX8_RT.Modules.PlatingCell { public class PlatingCellDryRoutine : RoutineBase, IRoutine { private enum RunRecipeStep { VerticalGotoDry, CheckVerticalGotoDry, ChangeRotation, RotationDelay, RotationStop, CheckRotationStoped, End } #region 常量 #endregion /// /// recipe /// private DepRecipe _recipe; /// /// Rotation axis /// private JetAxisBase _rotationAxis; /// /// Platingcell device /// private PlatingCellDevice _device; /// /// vertical axis entity /// private PlatingCellVerticalEntity _verticalEntity; /// /// 构造函数 /// /// public PlatingCellDryRoutine(string module) : base(module) { } /// /// 中止 /// public void Abort() { Runner.Stop("Manual Abort"); } /// /// 监控 /// /// public RState Monitor() { Runner.RunIf(RunRecipeStep.VerticalGotoDry, _recipe.RinseZoffset != _recipe.DryZoffset,() => StartVertical("Risne", _recipe.DryZoffset, 0, 0), _delay_1ms) .WaitWithStopConditionIf(RunRecipeStep.CheckVerticalGotoDry, _recipe.RinseZoffset != _recipe.DryZoffset, CheckVerticalEnd, CheckVerticalError) .Run(RunRecipeStep.ChangeRotation, () => ChangeRotationSpeed(_recipe.DrySpeed), _delay_1ms) .Delay(RunRecipeStep.RotationDelay, _recipe.DryTime * 1000) .Run(RunRecipeStep.RotationStop, _rotationAxis.StopPositionOperation, _delay_1ms) .WaitWithStopCondition(RunRecipeStep.CheckRotationStoped, CheckRotationPositionStatus, CheckRotationPositionRunStop) .End(RunRecipeStep.End, NullFun); return Runner.Status; } /// /// rotation改变速度 /// /// /// private bool ChangeRotationSpeed(int speed) { double _scale = _rotationAxis.ScaleFactor; speed = (int)Math.Round(_scale * BeckhoffVelocityUtil.ConvertVelocityToDegPerSecondByRPM(speed), 0); return _rotationAxis.ChangeSpeed(speed); } /// /// 检验Rotation移动状态 /// /// private bool CheckRotationPositionStatus() { return _rotationAxis.Status == RState.End; } /// /// 检验Rotation是否运动失败 /// /// private bool CheckRotationPositionRunStop() { return _rotationAxis.Status == RState.Failed || _rotationAxis.Status == RState.Timeout; } /// /// vertical 运行 /// /// 目标位置名称 /// 偏移量 /// private bool StartVertical(string positionName, double offset, int speed, int accelerate) { return _verticalEntity.CheckToPostMessage(Aitex.Core.RT.Log.eEvent.INFO_PLATINGCELL, Module, (int)PlatingCellVerticalEntity.VerticalMsg.Position, positionName, offset, speed, accelerate); } /// /// 检验垂直电机是否运动完成 /// /// private bool CheckVerticalEnd() { return _verticalEntity.IsIdle; } /// /// 检验垂直是否出现错误 /// /// private bool CheckVerticalError() { return _verticalEntity.IsError; } /// /// 启动 /// /// /// public RState Start(params object[] objs) { _recipe = (DepRecipe)objs[0]; _rotationAxis = DEVICE.GetDevice($"{Module}.Rotation"); _device = DEVICE.GetDevice(Module); //获取vertical entity string vertical = ModuleMatcherManager.Instance.GetPlatingVerticalByCell(Module); _verticalEntity = Singleton.Instance.GetModule(vertical); return Runner.Start(Module, "start Dry Routine"); } } }