SKVisionClient.cs 5.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141
  1. using SKMC.Api.Common;
  2. using System;
  3. using System.Collections.Generic;
  4. using System.Linq;
  5. using System.Text;
  6. using System.Threading.Tasks;
  7. namespace SKMC.Api.Device.Adapter.Vision
  8. {
  9. /// <summary>
  10. /// 视觉通讯协议基础客户端
  11. /// </summary>
  12. public class SKVisionClient
  13. {
  14. private readonly static ILogger log = LogFactory.Get();
  15. private readonly SKVisionClientBase clientBase;
  16. public SKVisionClient(int port, int timeout)
  17. {
  18. clientBase = new SKVisionClientBase(port, timeout);
  19. }
  20. /// <summary>
  21. /// 发送请求不接收结果
  22. /// </summary>
  23. /// <param name="moduleCode">模块码</param>
  24. /// <param name="functionCode">功能码</param>
  25. /// <param name="productCode">产品码</param>
  26. /// <param name="parameters">请求参数</param>
  27. public Task Request(string moduleCode, string functionCode, string productCode, bool isOnlySend,
  28. List<string> parameters = null)
  29. {
  30. string timeStamp = DateTime.Now.ToString("yyMMddHHmmssfff");
  31. SKVisionProtocol skVisionRequest = new SKVisionProtocol
  32. {
  33. Direction = "T",
  34. ModuleCode = moduleCode,
  35. FuncCode = functionCode,
  36. ProductCode = productCode,
  37. Timestamp = timeStamp,
  38. BodyDomains = parameters
  39. };
  40. clientBase.Request(skVisionRequest.ToRequest(), isOnlySend);
  41. return default;
  42. }
  43. /// <summary>
  44. /// 发送请求并接收结果 (同步模式)
  45. /// </summary>
  46. /// <param name="moduleCode">模块码</param>
  47. /// <param name="functionCode">功能码</param>
  48. /// <param name="productCode">产品码</param>
  49. /// <param name="parameters">请求参数</param>
  50. /// <param name="resultAction">解析函数</param>
  51. public Task Request(string moduleCode, string functionCode, string productCode,
  52. List<string> parameters = null, Action<SKVisionProtocol> resultAction = null)
  53. {
  54. string timeStamp = DateTime.Now.ToString("yyMMddHHmmssfff");
  55. SKVisionProtocol skVisionRequest = new SKVisionProtocol
  56. {
  57. Direction = "T",
  58. ModuleCode = moduleCode,
  59. FuncCode = functionCode,
  60. ProductCode = productCode,
  61. Timestamp = timeStamp,
  62. BodyDomains = parameters
  63. };
  64. clientBase.Request(skVisionRequest.ToRequest(),
  65. responseAction: (response) =>
  66. {
  67. resultAction?.Invoke(skVisionRequest.FromResponse(response));
  68. });
  69. return default;
  70. }
  71. /// <summary>
  72. /// 发送请求并接收结果 (异步模式)
  73. /// </summary>
  74. /// <param name="moduleCode"></param>
  75. /// <param name="functionCode"></param>
  76. /// <param name="productCode"></param>
  77. /// <param name="parameters"></param>
  78. /// <param name="responseAction"></param>
  79. /// <param name="resultAction"></param>
  80. /// <returns></returns>
  81. public Task Request(string moduleCode, string functionCode, string productCode,
  82. List<string> parameters = null, Action<SKVisionProtocol> responseAction = null, Action<SKVisionProtocol> resultAction = null)
  83. {
  84. string timeStamp = DateTime.Now.ToString("yyMMddHHmmssfff");
  85. // 是否粘包
  86. bool isMultiPacks = false;
  87. SKVisionProtocol skVisionRequest = new SKVisionProtocol
  88. {
  89. Direction = "T",
  90. ModuleCode = moduleCode,
  91. FuncCode = functionCode,
  92. ProductCode = productCode,
  93. Timestamp = timeStamp,
  94. BodyDomains = parameters
  95. };
  96. clientBase.Request(skVisionRequest.ToRequest(),
  97. responseAction: (response) =>
  98. {
  99. SKVisionProtocol skVisionProtocol = skVisionRequest.FromResponse(response);
  100. responseAction?.Invoke(skVisionRequest.FromResponse(response));
  101. // 有粘包
  102. if (skVisionProtocol.SKVisionSubProtocol != null)
  103. {
  104. log.Debug("粘包处理...");
  105. resultAction?.Invoke(skVisionProtocol.SKVisionSubProtocol);
  106. isMultiPacks = true;
  107. }
  108. });
  109. if (!isMultiPacks)
  110. {
  111. return Task.Run(() =>
  112. {
  113. string result = null;
  114. try
  115. {
  116. result = clientBase.GetResult();
  117. }
  118. catch (Exception e)
  119. {
  120. log.Error($"获取视觉结果异常: {e.Message}", e);
  121. }
  122. try
  123. {
  124. resultAction?.Invoke(skVisionRequest.FromResponse(result));
  125. }
  126. catch (Exception e)
  127. {
  128. log.Error($"处理视觉结果异常: {e.Message}", e);
  129. }
  130. });
  131. }
  132. return default;
  133. }
  134. }
  135. }