BMUManager.cs 5.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186
  1. using GSG.NET.Concurrent;
  2. using GSG.NET.Extensions;
  3. using GSG.NET.Logging;
  4. using GSG.NET.Quartz;
  5. using GSG.NET.Utils;
  6. using System;
  7. using System.Collections.Generic;
  8. using System.Linq;
  9. using System.Text;
  10. using System.Threading;
  11. using System.Threading.Tasks;
  12. using VehicleControlSystem.ControlLayer.Serial.DataModel;
  13. namespace VehicleControlSystem.ControlLayer.Serial.BatteryTabos
  14. {
  15. public class BMUManager
  16. {
  17. static Logger logger = Logger.GetLogger();
  18. Peak com = null;
  19. public Config BMUConfig { get; set; }
  20. public bool IsConnected { get; set; }
  21. internal Dictionary<string, ReceivedData> ReceivedDataDic = new Dictionary<string, DataModel.ReceivedData>();
  22. protected TsQueue<QueObject> qq = new TsQueue<QueObject>( 512 );
  23. public ThreadCancel cancel = new ThreadCancel();
  24. CbTimer polling = new CbTimer();
  25. long collectNo = 0;
  26. long collectElasped = 0;
  27. protected object LockObject = new object();
  28. #region Event
  29. public event Action<string> OnConnect;
  30. public event Action<string> OnDisconnect;
  31. public event Action<ReceivedData> OnChangedReceivedData;
  32. public event Action<List<ReceivedData>> OnFirstColtd;
  33. #endregion
  34. public BMUManager()
  35. {
  36. this.BMUConfig = new Config();
  37. this.Init();
  38. }
  39. private void Init()
  40. {
  41. EnumExtensions.GetValues<eDataKind>().ToList().ForEach( x => { this.ReceivedDataDic.Add( x.ToString(), new ReceivedData(x) ); } );
  42. }
  43. protected void EnqueueToNet( object o )
  44. {
  45. this.com.Enqueue( o );
  46. }
  47. protected void _ThPullQueue()
  48. {
  49. while ( !cancel.Canceled )
  50. {
  51. try
  52. {
  53. var qo = this.qq.Dequeue();
  54. if ( qo is QoConnect )
  55. DelegateUtils.Invoke( OnConnect, qo.Arg0 );
  56. else if ( qo is QoDisconnected )
  57. DelegateUtils.Invoke( OnDisconnect, qo.Arg0 );
  58. else if ( qo is QoReceivedDataChanged )
  59. DelegateUtils.Invoke( OnChangedReceivedData, qo.Arg0 );
  60. //else if ( qo is QoSendMessageSuccess )
  61. // DelegateUtils.Invoke( OnSendSetDataSuccess, qo.Arg0 );
  62. else
  63. Assert.Fail( "Unk Object {0}", qo );
  64. }
  65. catch ( ThreadAbortException )
  66. {
  67. break;
  68. }
  69. catch ( Exception e )
  70. {
  71. logger.E( e );
  72. }
  73. }
  74. }
  75. #region Net Invoke Method
  76. internal void _OnConnected()
  77. {
  78. if ( 0 != collectNo )
  79. this.qq.Enqueue( new QoConnect { Arg0 = this.BMUConfig.ID } );
  80. _OnTimePoll();
  81. }
  82. internal void _OnDisconnected()
  83. {
  84. this.qq.Enqueue( new QoDisconnected { Arg0 = this.BMUConfig.ID } );
  85. }
  86. internal void _InvokeChgdWordsAndBits()
  87. {
  88. //Todo: 변경 된 내용 처리.
  89. if ( 0 == collectNo )
  90. {
  91. //this.qq.Enqueue( new QoConnect { Arg0 = this.BMUConfig.ID } );
  92. var ll = this.ReceivedDataDic.Values.ToList();
  93. DelegateUtils.Invoke( OnFirstColtd, ll );
  94. }
  95. //var v = new MapScan
  96. //{
  97. // CollectTime = (int)SwUtils.Elapsed( collectElasped )
  98. //};
  99. //DlgUtils.Invoke( OnCollected, v );
  100. if ( long.MaxValue <= this.collectNo )
  101. this.collectNo = 1;
  102. this.collectNo++;
  103. var rlist = this.ReceivedDataDic.ToList();
  104. rlist.ForEach( r =>
  105. {
  106. if ( r.Value.IsChanged )
  107. {
  108. r.Value.IsChanged = false;
  109. var clone = ObjectCopyUtils.DeepClone( r );
  110. this.qq.Enqueue( new QoReceivedDataChanged { Arg0 = clone } );
  111. }
  112. } );
  113. //다음 timer 기동 시 까지 잠시 대기
  114. polling.Once( _OnTimePoll, 100 );
  115. }
  116. void _OnTimePoll()
  117. {
  118. //Todo: Scan 으로 읽어 오는 영역의 명령을 Net 쪽으로 보내야함.
  119. lock ( this.LockObject )
  120. {
  121. collectElasped = SwUtils.T;
  122. this.EnqueueToNet( new PollingObject() );
  123. this.EnqueueToNet( new DoInvokeChangedReceivedData() );//Invoke Changed
  124. }
  125. }
  126. //internal void _OnSendDataSuccess( ISetData data )
  127. //{
  128. // this.qq.Enqueue( new QoSendMessageSuccess { Arg0 = data } );
  129. //}
  130. #endregion
  131. #region Public Method
  132. public void Connect()
  133. {
  134. //외부 전달 시작
  135. this.cancel.AddGo( _ThPullQueue );
  136. //읽기 시작.
  137. this.com = new Peak(this);
  138. this.cancel.AddGo( this.com._ThreadPoolingReceiveData );
  139. }
  140. public void Disconnect()
  141. {
  142. collectNo = 0;
  143. //Thread Stop
  144. this.cancel.Cancel();
  145. this.cancel.StopWaitAll();
  146. }
  147. public void test()
  148. {
  149. var clone = this.ReceivedDataDic.Values.FirstOrDefault();
  150. this.qq.Enqueue( new QoReceivedDataChanged { Arg0 = clone } );
  151. }
  152. #endregion
  153. }
  154. }