MaxonHomeRoutine.cs 3.2 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394
  1. using Aitex.Core.RT.Log;
  2. using Aitex.Core.RT.Routine;
  3. using MECF.Framework.Common.CommonData.PUF;
  4. using MECF.Framework.Common.Routine;
  5. using CyberX8_Core;
  6. using System;
  7. using System.Collections.Generic;
  8. using System.Linq;
  9. using System.Text;
  10. using System.Threading.Tasks;
  11. namespace CyberX8_RT.Devices.AXIS.CANOpen
  12. {
  13. public class MaxonHomeRoutine : RoutineBase, IRoutine
  14. {
  15. private enum HomeStep
  16. {
  17. WriteControlWord,
  18. HomeModeOfOperation,
  19. WriteHomeControlWord,
  20. HomeDelay,
  21. CheckHome,
  22. NoneModeOfOperation,
  23. EnableOperation,
  24. End
  25. }
  26. #region 内部变量
  27. private JetAxisBase _axis;
  28. private int _timeout = 5000;
  29. private byte _homingMethod = 0;
  30. #endregion
  31. public MaxonHomeRoutine(string module,JetAxisBase axis) : base(module)
  32. {
  33. _axis = axis;
  34. }
  35. public void Abort()
  36. {
  37. Runner.Stop("Manual Abort");
  38. }
  39. public RState Monitor()
  40. {
  41. Runner.Run(HomeStep.WriteControlWord, () => { return _axis.WriteControlWord(0x0F); }, () => { return CheckControlWord(0x0F); }, 1000)
  42. .Run(HomeStep.HomeModeOfOperation, () => { return _axis.WriteModeOfMode(AxisModeOfOperation.HomingMode); },
  43. ()=> { return CheckModeOfOperation((byte)AxisModeOfOperation.HomingMode); }, 1000)
  44. .Run(HomeStep.WriteHomeControlWord, () => { return _axis.WriteControlWord(0x1F); }, () => { return CheckControlWord(0x1F); },1000)
  45. .Delay(HomeStep.HomeDelay,100)
  46. .WaitWithStopCondition(HomeStep.CheckHome,CheckHome,CheckErrorOrWarning,_timeout)
  47. .Run(HomeStep.NoneModeOfOperation, () => { return _axis.WriteModeOfMode(AxisModeOfOperation.None); },
  48. () => { return CheckModeOfOperation((byte)AxisModeOfOperation.None); },1000)
  49. .Run(HomeStep.EnableOperation, () => { return _axis.EnableOperation(); }, () => { return CheckControlWord(0x0F); },1000)
  50. .End(HomeStep.End,NullFun,100);
  51. return Runner.Status;
  52. }
  53. public bool CheckModeOfOperation(byte modeOfOperation)
  54. {
  55. return _axis.ModeOfOperation == modeOfOperation;
  56. }
  57. public bool CheckControlWord(ushort controlWord)
  58. {
  59. return _axis.ControlWord == controlWord;
  60. }
  61. private bool CheckHome()
  62. {
  63. return _axis.IsHomed;
  64. }
  65. /// 检验是否出错或告警
  66. /// </summary>
  67. /// <returns></returns>
  68. private bool CheckErrorOrWarning()
  69. {
  70. bool result = _axis.MotionData.Status.ToLower().Contains("error") || _axis.MotionData.Status.ToLower().Contains("warning");
  71. if (result)
  72. {
  73. LOG.WriteLog(eEvent.ERR_AXIS, Module, $"axis home occur error or warning");
  74. }
  75. return result;
  76. }
  77. public RState Start(params object[] objs)
  78. {
  79. _timeout = (int)objs[0];
  80. _homingMethod = (byte)objs[1];
  81. return Runner.Start(Module, "Home");
  82. }
  83. }
  84. }