| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138 | using Aitex.Core.RT.Log;using Aitex.Core.RT.Routine;using CyberX8_Core;using MECF.Framework.Common.Beckhoff.AxisProvider;using MECF.Framework.Common.CommonData.PUF;using MECF.Framework.Common.Routine;using System;namespace CyberX8_RT.Devices.AXIS.CanOpen{    public class CanOpenStopPositionRoutine : RoutineBase, IRoutine    {        private enum StopPositionStep        {            SetHaltControlWord,            CheckStop,            WriteTargePosition,            ResetHaltControlWord,            CheckRun,            NoneModeOfOperation,            EnableOperation,            End        }        #region 常量        private const string TARGET_POSITION = "TargetPosition";        #endregion        #region 内部变量        private JetAxisBase _axis;        private int _timeout = 5000;        private int _targetPosition;        /// <summary>        /// SRD rotation Provider对象        /// </summary>        private BeckhoffProviderAxis _rotationProviderAxis;        #endregion        public CanOpenStopPositionRoutine(string module, JetAxisBase axis) : base(module)        {            _axis = axis;        }        public void Abort()        {            Runner.Stop("Manual Abort");        }        public RState Monitor()        {            Runner.Run(StopPositionStep.SetHaltControlWord, () => { return _axis.WriteControlWord(0X8F); }, () => { return CheckControlWord(0X8F); }, 1000)                               .WaitWithStopCondition(StopPositionStep.CheckStop, CheckStop, CheckErrorOrWarning, _timeout)                .Run(StopPositionStep.WriteTargePosition, () => { return WriteTargetPosition(); }, NullFun, 100)                .Run(StopPositionStep.ResetHaltControlWord, () => { return _axis.WriteControlWord(0x3F); }, () => { return CheckControlWord(0x3F); }, 1000)                .WaitWithStopCondition(StopPositionStep.CheckRun, CheckRunEnd, CheckRunStop, 5000)                .Run(StopPositionStep.NoneModeOfOperation, () => { return _axis.WriteModeOfMode(AxisModeOfOperation.None); }, () => { return CheckModeOfOperation((byte)AxisModeOfOperation.None); }, 1000)                .Run(StopPositionStep.EnableOperation, () => { return _axis.EnableOperation(); }, () => { return CheckControlWord(0x0F); }, 1000)                .End(StopPositionStep.End, NullFun, 100);            return Runner.Status;        }        public bool CheckModeOfOperation(byte modeOfOperation)        {            return _axis.ModeOfOperation == modeOfOperation;        }        public bool CheckControlWord(ushort controlWord)        {            return _axis.ControlWord == controlWord;        }        /// <summary>        /// 设置目标位置为当前位置        /// </summary>        /// <param name="targetPosition"></param>        private bool WriteTargetPosition()         {            double scale = _rotationProviderAxis.ScaleFactor;            _targetPosition = (int)Math.Ceiling(_axis.MotionData.MotorPosition * scale);                                  return _axis.WriteVariable(TARGET_POSITION, _targetPosition);        }        /// <summary>        /// 检查是否运动完成        /// </summary>        /// <returns></returns>        private bool CheckRunEnd()        {            bool result = _axis.InTargetPosition && !_axis.IsRun;            return result;        }        /// <summary>        /// 检查是否运动完成        /// </summary>        /// <returns></returns>        private bool CheckRunStop()        {            //没有到达目标同时没有运动            bool isStop = !_axis.IsRun && !_axis.JudgeCurrentPositionIsInTargetPosition(_targetPosition);            if (isStop)            {                ErrorMsg = "position is stop";                return true;            }            return false;        }        /// <summary>        /// 检查Halt是否停下来        /// </summary>        /// <returns></returns>        private bool CheckStop()        {            return !_axis.IsRun;        }                /// 检验是否出错或告警        /// </summary>        /// <returns></returns>        private bool CheckErrorOrWarning()        {            bool result = _axis.MotionData.Status.ToLower().Contains("error") || _axis.MotionData.Status.ToLower().Contains("warning");            if (result)            {                LOG.WriteLog(eEvent.ERR_AXIS, Module, $"axis stop occur error or warning");            }            return result;        }        public RState Start(params object[] objs)        {            _rotationProviderAxis = BeckhoffAxisProviderManager.Instance.GetAxisProvider($"{Module}");            if (_rotationProviderAxis == null)            {                LOG.WriteLog(eEvent.ERR_AXIS, Module, $"{Module} Axist Provider is not exist");                return RState.Failed;            }            return Runner.Start(Module, "Stop Position");        }    }}
 |