PressureSensor.cpp 3.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131
  1. #include "PressureSensor.h"
  2. #include "Modbus.h"
  3. #include "ComStatistics.h"
  4. #include <QTimer>
  5. #include <QElapsedTimer>
  6. static ComStatistics g_PS_Statistics("PressureSensor");
  7. PressureSensor::PressureSensor(SerialUi* pSerial)
  8. {
  9. m_pSerial = pSerial;
  10. }
  11. bool PressureSensor::Read(float& pressure)
  12. {
  13. QByteArray tx_buf;
  14. QElapsedTimer timer;
  15. timer.start();
  16. char zero = 0x00;
  17. tx_buf.append(PRESSURESENSOR_ADDRESS);
  18. tx_buf.append(0x04);
  19. tx_buf.append(zero);
  20. tx_buf.append(zero);
  21. tx_buf.append(zero);
  22. tx_buf.append(0x02);
  23. unsigned short crc;
  24. crc=CRC16_MODBUS((unsigned char *)tx_buf.data(),tx_buf.size());
  25. tx_buf.append((crc>>8)&0xff);
  26. tx_buf.append(crc&0xff);
  27. g_PS_Statistics.ReQuestCount_increase();
  28. QByteArray rx_buf;
  29. rx_buf = m_pSerial->serialWriteReponse(tx_buf);
  30. if(rx_buf.size() > 0){
  31. if(check_crc(rx_buf)){
  32. char value[4];
  33. value[3] = rx_buf.at(5);
  34. value[2] = rx_buf.at(6);
  35. value[1] = rx_buf.at(3);
  36. value[0] = rx_buf.at(4);
  37. float* p = (float*)value;
  38. pressure = *p;
  39. g_PS_Statistics.Update_Recvtime(timer.elapsed());
  40. return true;
  41. }else{
  42. qDebug("PressureSensor::Read <<< check crc failed");
  43. g_PS_Statistics.CrcErrorCount_increase();
  44. return false;
  45. }
  46. }else{
  47. qDebug("PressureSensor::Read <<< no data received");
  48. g_PS_Statistics.TimeoutCount_increase();
  49. return false;
  50. }
  51. }
  52. bool PressureSensor::Set_Zero()
  53. {
  54. QByteArray tx_buf;
  55. QElapsedTimer timer;
  56. timer.start();
  57. char zero = 0x00;
  58. tx_buf.append(PRESSURESENSOR_ADDRESS);
  59. tx_buf.append(0x06);
  60. tx_buf.append(zero);
  61. tx_buf.append(0x1E);
  62. tx_buf.append(zero);
  63. tx_buf.append(0x01);
  64. unsigned short crc;
  65. crc=CRC16_MODBUS((unsigned char *)tx_buf.data(),tx_buf.size());
  66. tx_buf.append((crc>>8)&0xff);
  67. tx_buf.append(crc&0xff);
  68. g_PS_Statistics.ReQuestCount_increase();
  69. QByteArray rx_buf;
  70. rx_buf = m_pSerial->serialWriteReponse(tx_buf);
  71. if(rx_buf.size() > 0){
  72. if(check_crc(rx_buf)){
  73. g_PS_Statistics.Update_Recvtime(timer.elapsed());
  74. return true;
  75. }else{
  76. qDebug("PressureSensor::Set_Zero <<< check crc failed");
  77. g_PS_Statistics.CrcErrorCount_increase();
  78. return false;
  79. }
  80. }else{
  81. qDebug("PressureSensor::Set_Zero <<< no data received");
  82. g_PS_Statistics.TimeoutCount_increase();
  83. return false;
  84. }
  85. }
  86. bool PressureSensor::check_crc(QByteArray data)
  87. {
  88. int size = data.size();
  89. unsigned short crc1 =0, crc2= 0;
  90. unsigned char crc_h = data.at(size-2);
  91. unsigned char crc_l = data.at(size-1);
  92. crc1 = (crc_h <<8) |crc_l;
  93. crc2 = CRC16_MODBUS((unsigned char *)data.data(),data.size()-2);
  94. if(crc1 == crc2){
  95. return true;
  96. }else{
  97. return false;
  98. }
  99. }
  100. void PressureSensor::Dump_Statistics(QString file_path)
  101. {
  102. g_PS_Statistics.Save2File(file_path);
  103. }