SrdCommonChuckVacuumRoutine.cs 3.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101
  1. using Aitex.Core.RT.Device;
  2. using Aitex.Core.RT.Log;
  3. using Aitex.Core.RT.Routine;
  4. using Aitex.Core.RT.SCCore;
  5. using MECF.Framework.Common.Beckhoff.ModuleIO;
  6. using MECF.Framework.Common.Routine;
  7. using MECF.Framework.Common.TwinCat;
  8. using CyberX8_Core;
  9. using System;
  10. using System.Collections.Generic;
  11. using System.Linq;
  12. using System.Runtime.InteropServices;
  13. using System.Text;
  14. using System.Threading.Tasks;
  15. using MECF.Framework.Common.IOCore;
  16. namespace CyberX8_RT.Devices.SRD
  17. {
  18. public class SrdCommonChuckVacuumRoutine : RoutineBase, IRoutine
  19. {
  20. #region 常量
  21. private const string CHUCK_VACUUM = "ChuckVacuum";
  22. #endregion
  23. private enum ChuckVacuumStep
  24. {
  25. ChuckVauum,
  26. End
  27. }
  28. #region 内部变量
  29. private bool _chuckVacuum;
  30. private SrdCommonDevice _srdCommon;
  31. private int _timeout = 2000;
  32. private int _vacuumOnLimit;
  33. private int _vacuumOffLimit;
  34. #endregion
  35. /// <summary>
  36. /// 构造函数
  37. /// </summary>
  38. /// <param name="module"></param>
  39. public SrdCommonChuckVacuumRoutine(string module) : base(module)
  40. {
  41. }
  42. public void Abort()
  43. {
  44. Runner.Stop("Manual Abort");
  45. }
  46. public RState Monitor()
  47. {
  48. Runner.Run(ChuckVacuumStep.ChuckVauum, ChuckVacuum, CheckVacuumStatus, _timeout)
  49. .End(ChuckVacuumStep.End, NullFun, 100);
  50. return Runner.Status;
  51. }
  52. private bool ChuckVacuum()
  53. {
  54. string ioName = BeckhoffModuleIOManager.Instance.GetIoNameByInnerModuleName($"{Module}.{CHUCK_VACUUM}");
  55. return IOModuleManager.Instance.WriteIoValue(ioName, _chuckVacuum);
  56. }
  57. private bool CheckVacuumStatus()
  58. {
  59. if (_srdCommon.CommonData.ChuckVacuum == _chuckVacuum)
  60. {
  61. if(!_chuckVacuum)
  62. {
  63. LOG.WriteLog(eEvent.INFO_SRD, Module, $"Chuck Vacuum is on, VacuumValue:{_srdCommon.CommonData.VacuumValue}, VacuumOn Limit:{_vacuumOnLimit}");
  64. return _srdCommon.CommonData.VacuumValue < _vacuumOnLimit;
  65. }
  66. else
  67. {
  68. LOG.WriteLog(eEvent.INFO_SRD, Module, $"Chuck Vacuum is off, VacuumValue:{_srdCommon.CommonData.VacuumValue}, VacuumOn Limit:{_vacuumOffLimit}");
  69. return _srdCommon.CommonData.VacuumValue > _vacuumOffLimit;
  70. }
  71. }
  72. else
  73. {
  74. LOG.WriteLog(eEvent.INFO_SRD, Module, $"Chuck Vacuum is no equal to _chuckVacuum");
  75. return false;
  76. }
  77. }
  78. public RState Start(params object[] objs)
  79. {
  80. _chuckVacuum = (bool)objs[0];
  81. _srdCommon = DEVICE.GetDevice<SrdCommonDevice>($"{Module}.Common");
  82. _vacuumOffLimit = SC.GetValue<int>("SRD.ChuckVacuumOffLimit");
  83. _vacuumOnLimit = SC.GetValue<int>("SRD.ChuckVacuumOnLimit");
  84. if (_chuckVacuum)
  85. {
  86. return Runner.Start(Module, "Chuck Vacuum Off");
  87. }
  88. else
  89. {
  90. return Runner.Start(Module, "Chuck Vacuum On");
  91. }
  92. }
  93. }
  94. }