LoaderSideVacuumLevelCheckRoutine.cs 4.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130
  1. using Aitex.Core.RT.Device;
  2. using Aitex.Core.RT.Routine;
  3. using Aitex.Core.RT.SCCore;
  4. using MECF.Framework.Common.Beckhoff.ModuleIO;
  5. using MECF.Framework.Common.CommonData.PUF;
  6. using MECF.Framework.Common.Equipment;
  7. using MECF.Framework.Common.Routine;
  8. using MECF.Framework.Common.TwinCat;
  9. using CyberX8_Core;
  10. using CyberX8_RT.Devices.Loader;
  11. using System;
  12. using System.Collections.Generic;
  13. using System.Linq;
  14. using System.Text;
  15. using System.Threading.Tasks;
  16. namespace CyberX8_RT.Devices.AXIS.CANOpen
  17. {
  18. public class LoaderSideVacuumLevelCheckRoutine : RoutineBase, IRoutine
  19. {
  20. private enum VacuumStep
  21. {
  22. WriteVacuum,
  23. End
  24. }
  25. #region 常量
  26. private const string CRS_VACUUM = "CRSVacuum";
  27. #endregion
  28. #region 内部变量
  29. private int _timeout = 5000;
  30. private LoaderSideDevice _loaderSide;
  31. private bool _vacuum = false;
  32. private double _crsVacuumHighLimit = -550;
  33. private double _crsVacuumLowLimit = -480;
  34. #endregion
  35. /// <summary>
  36. /// 构造函数
  37. /// </summary>
  38. /// <param name="module"></param>
  39. public LoaderSideVacuumLevelCheckRoutine(string module) : base(module)
  40. {
  41. }
  42. /// <summary>
  43. /// 中止
  44. /// </summary>
  45. public void Abort()
  46. {
  47. Runner.Stop("Manual Abort");
  48. }
  49. /// <summary>
  50. /// 监控
  51. /// </summary>
  52. /// <returns></returns>
  53. public RState Monitor()
  54. {
  55. Runner.Run(VacuumStep.WriteVacuum, NullFun, CheckVacuum,_timeout)
  56. .End(VacuumStep.End,NullFun,100);
  57. return Runner.Status;
  58. }
  59. /// <summary>
  60. /// 检验Vacuum状态
  61. /// </summary>
  62. /// <returns></returns>
  63. private bool CheckVacuum()
  64. {
  65. bool result = false;
  66. if (_vacuum)
  67. {
  68. result= _loaderSide.SideData.CRSVacuumValue < 0 && _loaderSide.SideData.CRSVacuumValue < _crsVacuumHighLimit;
  69. if (!result)
  70. {
  71. if (_loaderSide.SideData.CRSVacuumValue >= _crsVacuumHighLimit)
  72. {
  73. NotifyError(Aitex.Core.RT.Log.eEvent.INFO_LOADER, $"vacuum value {_loaderSide.SideData.CRSVacuumValue} is over or equal {_crsVacuumHighLimit}", 0);
  74. return false;
  75. }
  76. if (_loaderSide.SideData.CRSVacuumValue >= 0)
  77. {
  78. NotifyError(Aitex.Core.RT.Log.eEvent.INFO_LOADER, $"vacuum value {_loaderSide.SideData.CRSVacuumValue} is over or equal 0", 0);
  79. return false;
  80. }
  81. }
  82. }
  83. else
  84. {
  85. result= _loaderSide.SideData.CRSVacuumValue > _crsVacuumLowLimit && _loaderSide.SideData.CRSVacuumValue < 0;
  86. if (_loaderSide.SideData.CRSVacuumValue <= _crsVacuumLowLimit)
  87. {
  88. NotifyError(Aitex.Core.RT.Log.eEvent.INFO_LOADER, $"vacuum value {_loaderSide.SideData.CRSVacuumValue} is less or equal {_crsVacuumLowLimit}", 0);
  89. return false;
  90. }
  91. if (_loaderSide.SideData.CRSVacuumValue >= 0)
  92. {
  93. NotifyError(Aitex.Core.RT.Log.eEvent.INFO_LOADER, $"vacuum value {_loaderSide.SideData.CRSVacuumValue} is over or equal 0", 0);
  94. return false;
  95. }
  96. }
  97. return result;
  98. }
  99. /// <summary>
  100. /// 启动
  101. /// </summary>
  102. /// <param name="objs"></param>
  103. /// <returns></returns>
  104. public RState Start(params object[] objs)
  105. {
  106. if (SC.ContainsItem($"{ModuleName.Loader1}.LSVacuumTimeout"))
  107. {
  108. _timeout = SC.GetValue<int>($"{ModuleName.Loader1}.LSVacuumTimeout");
  109. }
  110. if (SC.ContainsItem($"{ModuleName.Loader1}.LSVacuumHighLimit"))
  111. {
  112. _crsVacuumHighLimit = SC.GetValue<double>($"{ModuleName.Loader1}.LSVacuumHighLimit");
  113. }
  114. if (SC.ContainsItem($"{ModuleName.Loader1}.LSVacuumLowLimit"))
  115. {
  116. _crsVacuumLowLimit = SC.GetValue<double>($"{ModuleName.Loader1}.LSVacuumLowLimit");
  117. }
  118. _vacuum = (bool)objs[0];
  119. _loaderSide = DEVICE.GetDevice<LoaderSideDevice>(Module);
  120. return Runner.Start(Module, "Vacuum Level Check");
  121. }
  122. }
  123. }