ZmqManager.cs 9.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317
  1. using GSG.NET.Concurrent;
  2. using GSG.NET.Logging;
  3. using GSG.NET.ObjectBase;
  4. using NetMQ;
  5. using NetMQ.Monitoring;
  6. using NetMQ.Sockets;
  7. using OHV.Common.Model;
  8. using OHV.Common.Shareds;
  9. using System;
  10. using System.Collections.Generic;
  11. using System.Linq;
  12. using System.Text;
  13. using System.Threading.Tasks;
  14. namespace VehicleControlSystem.ControlLayer.MQ
  15. {
  16. public class ZmqManager : ControlObjectBase, IDisposable
  17. {
  18. Logger logger = Logger.GetLogger();
  19. SubscriberSocket sub = null;
  20. RequestSocket req = null;
  21. ResponseSocket rep = null;
  22. NetMQPoller poller = null;
  23. NetMQMonitor monitor = null;
  24. ThreadCancel threadCancel = new ThreadCancel();
  25. private bool isReqConnected;
  26. public bool IsReqConnected
  27. {
  28. get { return isReqConnected; }
  29. set { isReqConnected = value; }
  30. }
  31. #region Properties
  32. private eSteeringState requestSteering;
  33. public eSteeringState RequestSteering
  34. {
  35. get { return requestSteering; }
  36. set { SetField( ref this.requestSteering, value ); }
  37. }
  38. private bool isDriveMoving;
  39. public bool IsDriveMoving
  40. {
  41. get { return isDriveMoving; }
  42. set { SetField( ref isDriveMoving, value ); }
  43. }
  44. private eRoadForm currentLoadForm;
  45. public eRoadForm CurrentLoadForm
  46. {
  47. get { return currentLoadForm; }
  48. set { SetField( ref currentLoadForm, value ); }
  49. }
  50. private eOperatationMode operatationMode;
  51. public eOperatationMode OperationMode
  52. {
  53. get { return operatationMode; }
  54. set { operatationMode = value; }
  55. }
  56. #endregion
  57. public ZmqManager()
  58. {
  59. NetMQ.NetMQConfig.Cleanup();
  60. }
  61. public void Init()
  62. {
  63. rep = new ResponseSocket();
  64. rep.Bind( "tcp://127.0.0.1:5568" );
  65. rep.ReceiveReady += Rep_ReceiveReady;
  66. sub = new SubscriberSocket();
  67. sub.Connect( "tcp://127.0.0.1:5565" );
  68. sub.Connect( "tcp://127.0.0.1:5566" );
  69. sub.Subscribe( "" ); //All
  70. sub.ReceiveReady += Sub_ReceiveReady;
  71. req = new RequestSocket();
  72. this.monitor = new NetMQMonitor( req, "inproc://rep.inproc", SocketEvents.Disconnected | SocketEvents.Connected );
  73. this.monitor.Connected += ( s, a ) => { this.IsReqConnected = true; };
  74. this.monitor.Disconnected += ( s, a ) => { this.IsReqConnected = false; };
  75. this.monitor.StartAsync();
  76. req.Connect( "tcp://127.0.0.1:5567" );
  77. this.poller = new NetMQPoller { this.sub, this.rep };
  78. this.poller.RunAsync();
  79. }
  80. public void Dispose()
  81. {
  82. this.threadCancel.Cancel();
  83. this.monitor.Stop();
  84. this.monitor.Dispose();
  85. this.poller.Stop();
  86. this.poller.Dispose();
  87. this.sub.Dispose();
  88. this.req.Dispose();
  89. }
  90. private void Rep_ReceiveReady( object sender, NetMQSocketEventArgs e )
  91. {
  92. var ret = e.Socket.ReceiveMultipartStrings();
  93. logger.D( $"[rep] - {ret}" );
  94. if ( ret[0].Equals( "setm" ) )
  95. {
  96. var v = ret[1].Split( '/' );
  97. switch ( v[0] )
  98. {
  99. case "3050":
  100. {
  101. switch ( v[1] )
  102. {
  103. case "1":
  104. this.RequestSteering = eSteeringState.Left;
  105. break;
  106. case "-1":
  107. this.RequestSteering = eSteeringState.Right;
  108. break;
  109. default:
  110. this.RequestSteering = eSteeringState.None;
  111. break;
  112. }
  113. }
  114. break;
  115. case "111":
  116. {
  117. if ( v[1].Equals( "1" ) )
  118. OperationMode = eOperatationMode.AutoMode;
  119. else
  120. OperationMode = eOperatationMode.ManualMode;
  121. }
  122. break;
  123. case "113":
  124. {
  125. }
  126. break;
  127. default:
  128. break;
  129. }
  130. rep.SendMoreFrame( "setm" ).SendFrame( $"ok/{v[0]}" );
  131. }
  132. }
  133. private void Sub_ReceiveReady( object sender, NetMQ.NetMQSocketEventArgs e )
  134. {
  135. var ret = e.Socket.ReceiveMultipartStrings();
  136. logger.I( ret );
  137. switch ( ret[0] )
  138. {
  139. case "3050": //TargetSteering
  140. {
  141. //switch ( ret[1] )
  142. //{
  143. // case "1":
  144. // this.RequestSteering = eSteeringState.Left;
  145. // break;
  146. // case "-1":
  147. // this.RequestSteering = eSteeringState.Right;
  148. // break;
  149. // default:
  150. // this.RequestSteering = eSteeringState.None;
  151. // break;
  152. //}
  153. }
  154. break;
  155. case "111": //0=StartUp, 1=DeviceOpened, 2=DiviceOpenFailed, 3=ManualOP, 4=AutomaticOp, 5=DeviceCloseed, 6=Finished
  156. break;
  157. case "3010": //진행중의 길의 모양, 0이면 정지 상태
  158. {
  159. var v = ret[1].Split( ';' );
  160. switch ( v[0] )
  161. {
  162. case "1":
  163. //this.RequestSteering = eSteeringState.Left;
  164. break;
  165. case "-1":
  166. //this.RequestSteering = eSteeringState.Right;
  167. break;
  168. default:
  169. //this.RequestSteering = eSteeringState.None;
  170. break;
  171. }
  172. }
  173. break;
  174. default:
  175. break;
  176. }
  177. }
  178. void Th_SubPoller()
  179. {
  180. while ( !this.threadCancel.Canceled )
  181. {
  182. LockUtils.Wait( 1000 );
  183. //this.pub.SendMoreFrame( "1000" ).SendFrame( "Test" );
  184. LockUtils.Wait( 100 );
  185. NetMQMessage msg = new NetMQMessage();
  186. if ( this.sub.TryReceiveMultipartMessage( TimeSpan.FromSeconds( 1 ), ref msg ) )
  187. {
  188. var m = msg;
  189. }
  190. }
  191. }
  192. bool Request( string topic, string value, out string response )
  193. {
  194. List<string> repll = new List<string>();
  195. response = string.Empty;
  196. if ( !this.IsReqConnected )
  197. return false;
  198. if ( !this.req.HasIn )
  199. this.req.SendMoreFrame( topic ).SendFrame( value );
  200. if ( this.req.TryReceiveMultipartStrings( TimeSpan.FromSeconds( 5 ), ref repll ) )
  201. return true;
  202. else
  203. return false;
  204. }
  205. #region Request Mothed
  206. internal void SetObstruction( eObstacleState state )
  207. {
  208. string outStr = string.Empty;
  209. switch ( state )
  210. {
  211. case eObstacleState.Normal:
  212. this.Request( "set", "5001/0", out outStr );
  213. break;
  214. case eObstacleState.Abnormal:
  215. this.Request( "set", "5001/3", out outStr );
  216. break;
  217. case eObstacleState.Blocked:
  218. this.Request( "set", "5001/2", out outStr );
  219. break;
  220. case eObstacleState.Decelerate:
  221. this.Request( "set", "5001/1", out outStr );
  222. break;
  223. default:
  224. break;
  225. }
  226. }
  227. internal void SetOperationSate(eOperatationMode mode)
  228. {
  229. string outStr = string.Empty;
  230. if ( mode == eOperatationMode.AutoMode )
  231. this.Request( "set", "112/1", out outStr );
  232. else if ( mode == eOperatationMode.ManualMode )
  233. this.Request( "set", "112/0", out outStr );
  234. else
  235. { }
  236. }
  237. internal void SetMCState(bool isOn )
  238. {
  239. string outStr = string.Empty;
  240. if ( isOn )
  241. this.Request( "set", "5000/1", out outStr );
  242. else
  243. this.Request( "set", "5000/0", out outStr );
  244. }
  245. internal void SetCurrentSteeringState( eSteeringState state )
  246. {
  247. string outStr = string.Empty;
  248. bool ret = false;
  249. switch ( state )
  250. {
  251. case eSteeringState.None:
  252. ret = this.Request( "set", "3060/0/0", out outStr );
  253. break;
  254. case eSteeringState.Left:
  255. ret = this.Request( "set", "3060/0/1", out outStr );
  256. break;
  257. case eSteeringState.Right:
  258. ret = this.Request( "set", "3060/0/-1", out outStr );
  259. break;
  260. default:
  261. break;
  262. }
  263. }
  264. #endregion
  265. }
  266. }