using Aitex.Core.RT.Device; using Aitex.Core.RT.Routine; using Aitex.Core.RT.SCCore; 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.Reflection; using System.Text; using System.Threading.Tasks; namespace PunkHPX8_RT.Modules.PlatingCell { public class PlatingCellRinseRoutine : RoutineBase, IRoutine { private enum RunRecipeStep { VerticalGotoRinse, CheckVerticalGotoRinse, OpenRinseValve, ChangeRotation, RotationDelay, CloseRinseValve, End } #region 常量 #endregion /// /// recipe /// private DepRecipe _recipe; /// /// Rotation axis /// private JetAxisBase _rotationAxis; /// /// Platingcell device /// private PlatingCellDevice _device; /// /// vertical axis entity /// private PlatingCellVerticalEntity _verticalEntity; /// /// 构造函数 /// /// public PlatingCellRinseRoutine(string module) : base(module) { } /// /// 中止 /// public void Abort() { Runner.Stop("Manual Abort"); } /// /// 监控 /// /// public RState Monitor() { Runner.Run(RunRecipeStep.VerticalGotoRinse, () => StartVertical("Rinse", _recipe.RinseZoffset, 0, 0), _delay_1ms) .WaitWithStopCondition(RunRecipeStep.CheckVerticalGotoRinse, CheckVerticalEnd, CheckVerticalError) .Run(RunRecipeStep.OpenRinseValve, () => _device.RinseEnableAction(),_delay_1ms) .Run(RunRecipeStep.ChangeRotation, () => ChangeRotationSpeed(_recipe.RinseSpeed), _delay_1ms) .Delay(RunRecipeStep.RotationDelay, _recipe.RinseTime*1000) .Run(RunRecipeStep.CloseRinseValve, () => _device.RinseDisableAction(),_delay_1ms) .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); } /// /// 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 rinse routine"); } } }