radar_can.cpp 5.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197
  1. #include "radar_can.h"
  2. #include "message_queue.h"
  3. CCanRadarSensor::CCanRadarSensor(CMessageQueue* q) :_message(q)
  4. {
  5. _run = false;
  6. }
  7. void CCanRadarSensor::SetCanBusSensor(SensorCanBus<CCanRadarSensor>* can)
  8. {
  9. _canbus = can;
  10. }
  11. void CCanRadarSensor::Start()
  12. {
  13. if(!_run)
  14. {
  15. _run = true;
  16. _count = 0;
  17. }
  18. }
  19. void CCanRadarSensor::Run()
  20. {
  21. if (_run)
  22. {
  23. }
  24. }
  25. void CCanRadarSensor::Stop()
  26. {
  27. if (_run)
  28. {
  29. _run = false;
  30. _count = 0;
  31. }
  32. }
  33. uint16_t CCanRadarSensor::bcd2dec(uint8_t data0, uint8_t data1)
  34. {
  35. unsigned char Dst[4];
  36. memset(Dst, 0, 4);
  37. uint16_t i = (((data0 & 0x00FF) << 8) | (data1 & 0x00FF));
  38. sprintf((char *)Dst, "%x", i);
  39. return strtol((const char *)Dst, NULL, 10);
  40. }
  41. // void CCanRadarSensor::Notify(struct can_frame *date)
  42. // {
  43. // if(_run)
  44. // {
  45. // if ((htonl(date->can_id) & 0x60B) == 0x60B)
  46. // {
  47. // int Nl_Index = (int)(((htonl(date->can_id)) & 0x00f0) >> 4);
  48. // switch (Nl_Index)
  49. // {
  50. // case 1:
  51. // _data.r0 = ((((date->data[1] * 32) + (date->data[2] >> 3)) * 0.2) - 500);
  52. // break;
  53. // case 2:
  54. // _data.r1 = ((((date->data[1] * 32) + (date->data[2] >> 3)) * 0.2) - 500);
  55. // break;
  56. // case 3:
  57. // _data.r2 = ((((date->data[1] * 32) + (date->data[2] >> 3)) * 0.2) - 500);
  58. // break;
  59. // case 4:
  60. // _data.r3 = ((((date->data[1] * 32) + (date->data[2] >> 3)) * 0.2) - 500);
  61. // break;
  62. // case 5:
  63. // _data.r4 = ((((date->data[1] * 32) + (date->data[2] >> 3)) * 0.2) - 500);
  64. // break;
  65. // case 6:
  66. // _data.r5 = ((((date->data[1] * 32) + (date->data[2] >> 3)) * 0.2) - 500);
  67. // break;
  68. // case 7:
  69. // _data.r6 = ((((date->data[1] * 32) + (date->data[2] >> 3)) * 0.2) - 500);
  70. // break;
  71. // case 8:
  72. // _data.r7 = ((((date->data[1] * 32) + (date->data[2] >> 3)) * 0.2) - 500);
  73. // break;
  74. // default:
  75. // break;
  76. // }
  77. // std::cout << "radar :" << _data.r0 << " " << _data.r1 << " " << _data.r2 << " " << _data.r3 << " "
  78. // << _data.r4 << " " << _data.r5 << " " << _data.r6 << " " << _data.r7 << " "<< std::endl;
  79. // }
  80. // _count++;
  81. // if (_count > 8)
  82. // {
  83. // _message->WriteRadarData(_data);
  84. // _count = 0;
  85. // }
  86. // }
  87. // }
  88. #include <chrono>
  89. void CCanRadarSensor::Notify(struct can_frame *date)
  90. {
  91. //auto start = std::chrono::system_clock::now();
  92. if(_run)
  93. {
  94. if (date -> can_id == 0x61b){
  95. int c_l_1 = date->data[1];
  96. int c_l_2 = date->data[2];
  97. c_l_1 = c_l_1 * 32;
  98. c_l_2 = c_l_2 >> 3;
  99. int32_t dis_long2 = ((c_l_1 + c_l_2) * 0.2f - 500.0f) * 1000; // 毫米 纵向
  100. _data.r0 = dis_long2;
  101. _count++;
  102. }
  103. else if (date -> can_id == 0x62b){
  104. int c_l_1 = date->data[1];
  105. int c_l_2 = date->data[2];
  106. c_l_1 = c_l_1 * 32;
  107. c_l_2 = c_l_2 >> 3;
  108. int32_t dis_long2 = ((c_l_1 + c_l_2) * 0.2f - 500.0f) * 1000; // 毫米 纵向
  109. _data.r1 = dis_long2;
  110. // _data.r2 = dis_long2;
  111. _count++;
  112. }
  113. else if (date -> can_id == 0x63b){
  114. int c_l_1 = date->data[1];
  115. int c_l_2 = date->data[2];
  116. c_l_1 = c_l_1 * 32;
  117. c_l_2 = c_l_2 >> 3;
  118. int32_t dis_long2 = ((c_l_1 + c_l_2) * 0.2f - 500.0f) * 1000; // 毫米 纵向
  119. _data.r2 = dis_long2;
  120. // _data.r4 = dis_long2;
  121. _count++;
  122. }
  123. else if (date -> can_id == 0x64b){
  124. int c_l_1 = date->data[1];
  125. int c_l_2 = date->data[2];
  126. c_l_1 = c_l_1 * 32;
  127. c_l_2 = c_l_2 >> 3;
  128. int32_t dis_long2 = ((c_l_1 + c_l_2) * 0.2f - 500.0f) * 1000; // 毫米 纵向
  129. _data.r3 = dis_long2;
  130. // _data.r6 = dis_long2;
  131. _count++;
  132. }
  133. else if (date-> can_id== 0x611)
  134. {
  135. _data.r4 = bcd2dec(date->data[0], date->data[1]);
  136. _data.r5 = bcd2dec(date->data[2], date->data[3]);
  137. _data.r6 = bcd2dec(date->data[4], date->data[5]);
  138. _data.r7 = bcd2dec(date->data[6], date->data[7]);
  139. _count += 4;
  140. }
  141. //std::cout << "radar :" << _data.r0 << " " << _data.r1 << " " << _data.r2 << " " << _data.r3 << " "
  142. //<< _data.r4 << " " << _data.r5 << " " << _data.r6 << " " << _data.r7 << " "<< std::endl;
  143. // _count++;
  144. if (_count > 8)
  145. {
  146. _message->WriteRadarData(_data);
  147. _count = 0;
  148. }
  149. //std::this_thread::sleep_for(std::chrono::milliseconds(20));
  150. // 执行一些操作
  151. //auto end = std::chrono::system_clock::now();
  152. //std::chrono::duration<double> elapsed = end - start;
  153. //std::cout << "Elapsed time: " << elapsed.count() << " seconds" << std::endl;
  154. }
  155. }