ModuleMatcherManager.cs 4.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115
  1. using Aitex.Core.Util;
  2. using MECF.Framework.Common.Equipment;
  3. using System;
  4. using System.Collections.Generic;
  5. using System.Linq;
  6. using System.Text;
  7. using System.Threading.Tasks;
  8. namespace PunkHPX8_RT.Modules
  9. {
  10. public class ModuleMatcherManager : Singleton<ModuleMatcherManager>
  11. {
  12. #region 常量
  13. private Dictionary<string, string> _matcher =new Dictionary<string, string>
  14. {
  15. { ModuleName.PlatingCell1.ToString(),ModuleName.PlatingCell2.ToString()},
  16. { ModuleName.PlatingCell2.ToString(),ModuleName.PlatingCell1.ToString()},
  17. { ModuleName.PlatingCell3.ToString(),ModuleName.PlatingCell4.ToString()},
  18. { ModuleName.PlatingCell4.ToString(),ModuleName.PlatingCell3.ToString()},
  19. { ModuleName.PlatingCell5.ToString(),ModuleName.PlatingCell6.ToString()},
  20. { ModuleName.PlatingCell6.ToString(),ModuleName.PlatingCell5.ToString()},
  21. { ModuleName.PlatingCell7.ToString(),ModuleName.PlatingCell8.ToString()},
  22. { ModuleName.PlatingCell8.ToString(),ModuleName.PlatingCell7.ToString()},
  23. { ModuleName.PlatingCell9.ToString(),ModuleName.PlatingCell10.ToString()},
  24. { ModuleName.PlatingCell10.ToString(),ModuleName.PlatingCell9.ToString()},
  25. { ModuleName.VPW1.ToString(),ModuleName.VPW2.ToString()},
  26. { ModuleName.VPW2.ToString(),ModuleName.VPW1.ToString()},
  27. };
  28. private Dictionary<string, string> _platingCellVerticalMatcher = new Dictionary<string, string>();
  29. /// <summary>
  30. /// 垂直电机Matcher集合字典
  31. /// </summary>
  32. private Dictionary<string, List<string>> _verticalMatcherListDic = new Dictionary<string, List<string>>();
  33. #endregion
  34. /// <summary>
  35. /// 获取配对模块
  36. /// </summary>
  37. /// <param name="module"></param>
  38. /// <returns></returns>
  39. public string GetMatcherByModule(string module)
  40. {
  41. if (_matcher.ContainsKey(module)){
  42. return _matcher[module];
  43. }
  44. else
  45. {
  46. return "";
  47. }
  48. }
  49. /// <summary>
  50. /// 初始化PlatingCell和垂直电机ID
  51. /// </summary>
  52. /// <param name="platingCellId"></param>
  53. /// <param name="verticalId"></param>
  54. public void InitialPlatingCellVerticalID(string platingCellId,string verticalId)
  55. {
  56. _platingCellVerticalMatcher[platingCellId] = verticalId;
  57. List<string> list = null;
  58. if (_verticalMatcherListDic.ContainsKey(verticalId))
  59. {
  60. list= _verticalMatcherListDic[verticalId];
  61. }
  62. else
  63. {
  64. list = new List<string>();
  65. _verticalMatcherListDic[verticalId] = list;
  66. }
  67. if (!list.Contains(platingCellId))
  68. {
  69. list.Add(platingCellId);
  70. }
  71. }
  72. /// <summary>
  73. /// 获取所有的PlatingCell的垂直电机集合
  74. /// </summary>
  75. /// <returns></returns>
  76. public List<string> GetAllPlatingCellVertialList()
  77. {
  78. return _platingCellVerticalMatcher.Values.Distinct().ToList();
  79. }
  80. /// <summary>
  81. /// 根据Plating获取Vertical
  82. /// </summary>
  83. /// <param name="cell"></param>
  84. /// <returns></returns>
  85. public string GetPlatingVerticalByCell(string cell)
  86. {
  87. if (_platingCellVerticalMatcher.ContainsKey(cell))
  88. {
  89. return _platingCellVerticalMatcher[cell];
  90. }
  91. else
  92. {
  93. return "";
  94. }
  95. }
  96. /// <summary>
  97. /// 获取垂直电机的Mathcer集合
  98. /// </summary>
  99. /// <param name="vertical"></param>
  100. /// <returns></returns>
  101. public List<string> GetMatcherListByVertical(string vertical)
  102. {
  103. if (_verticalMatcherListDic.ContainsKey(vertical))
  104. {
  105. return _verticalMatcherListDic[vertical];
  106. }
  107. else
  108. {
  109. return null;
  110. }
  111. }
  112. }
  113. }