DetectorConfiguration.cpp 3.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119
  1. #include "stdafx.h"
  2. #include "DetectorConfiguration.h"
  3. #include "Detector_Model_Def.h"
  4. extern Log4CPP::Logger* gLogger;
  5. DetectorConfiguration::DetectorConfiguration(string ConfigPath)
  6. {
  7. m_strConfigPath = ConfigPath;
  8. }
  9. DetectorConfiguration::~DetectorConfiguration()
  10. {
  11. }
  12. bool DetectorConfiguration::LoadConfigurations(DeviceIndexStruct & DeviceConf, ResDataObject & ACQMODElist)
  13. {
  14. printf("LoadConfigurations config path:%s\n", m_strConfigPath.c_str());
  15. FINFO("LoadConfigurations config path:{$}", m_strConfigPath);
  16. if (!m_ConfigAll.loadFile(m_strConfigPath.c_str()))
  17. {
  18. printf("Load configuration file failed!!! \n");
  19. return false;
  20. }
  21. try
  22. {
  23. m_Configurations = m_ConfigAll["CONFIGURATION"];
  24. DeviceConf.strDeviceName = (string)m_Configurations[DetectorDescription];
  25. DeviceConf.strPanelSerial = (string)m_Configurations["SerialNumber"];
  26. int maxImageSize = 0;
  27. int nModeCount = (int)m_Configurations["ModeTable"].size();
  28. FINFO("nModeCount:{$}", nModeCount);
  29. for (int i = 0; i < nModeCount; i++)
  30. {
  31. FINFO("ModeTable[{$}]:{$}", i, m_Configurations["ModeTable"][i].encode());
  32. DeviceConf.nRawWidth = m_Configurations["ModeTable"][i]["RawImgWidth"];
  33. DeviceConf.nRawHeight = m_Configurations["ModeTable"][i]["RawImgHeight"];
  34. DeviceConf.nDoseOfEXI = (int)m_Configurations["ModeTable"][i]["Sensitivity"];
  35. if (DeviceConf.nRawWidth * DeviceConf.nRawHeight > maxImageSize)
  36. {
  37. maxImageSize = DeviceConf.nRawWidth * DeviceConf.nRawHeight;
  38. DeviceConf.nMaxImageWidth = DeviceConf.nRawWidth;
  39. DeviceConf.nMaxImageHeight = DeviceConf.nRawHeight;
  40. }
  41. }
  42. FINFO("DeviceConf.nMaxImageWidth:{$},DeviceConf.nMaxImageHeight:{$}", DeviceConf.nMaxImageWidth, DeviceConf.nMaxImageHeight);
  43. DeviceConf.fTemperMaxLimit = (float)m_Configurations["TempMaxLimit"];//最高温度
  44. DeviceConf.fTemperUpperLimit = (float)m_Configurations["TempUpperLimit"];//高温警告值
  45. DeviceConf.fTemperLowLimit = (float)m_Configurations["TempLowerLimit"];//低温警告值
  46. DeviceConf.fTemperMinLimit = (float)m_Configurations["TempMinLimit"];//最低温度
  47. DeviceConf.nBatteryWarning = (int)m_Configurations["BatLowerLimit"];//低电量警告值
  48. DeviceConf.nBatteryLimit = (int)m_Configurations["BatMiniLimit"];//最低电量
  49. DeviceConf.nWifiWarning = (int)m_Configurations["WifiLowerLimit"];//wifi信号低警告
  50. DeviceConf.nWifiLimit = (int)m_Configurations["WifiMiniLimit"];//WiFi信号最低
  51. }
  52. catch (ResDataObjectExption &e)
  53. {
  54. printf("Get config error: %s \r\n", e.what());
  55. return false;
  56. }
  57. return true;
  58. }
  59. bool DetectorConfiguration::SaveConfig()
  60. {
  61. try
  62. {
  63. m_ConfigAll["CONFIGURATION"] = m_Configurations;
  64. }
  65. catch (...)
  66. {
  67. return false;
  68. }
  69. return m_ConfigAll.SaveFile((m_strConfigPath).c_str());
  70. }
  71. bool DetectorConfiguration::LoadCalibrationDose(string& strWorkPath, ResDataObject& CalibDoseList, int& nTotalExposeNum)
  72. {
  73. ResDataObject RdoCalibDoseList;
  74. try
  75. {
  76. //FINFO("LoadCalibrationDose: {$}", m_Configurations.encode());
  77. string strCalibDosePath = strWorkPath + (string)m_Configurations["CalibrationDosePath"] + "\\CalibrationDose_PZMedical.xml";
  78. FINFO("strCalibDosePath: {$}", strCalibDosePath);
  79. struct stat buffer;
  80. if (stat(strCalibDosePath.c_str(), &buffer) == 0)
  81. {
  82. RdoCalibDoseList.loadFile(strCalibDosePath.c_str());
  83. CalibDoseList = RdoCalibDoseList["List"];
  84. FINFO("CalibDoseList: {$} ", CalibDoseList.encode());
  85. for (int i = 0; i < CalibDoseList.size(); i++)
  86. {
  87. ResDataObject temp = CalibDoseList[i];
  88. int nExpNum = temp["ExpNum"];
  89. nTotalExposeNum += nExpNum;
  90. }
  91. FINFO("CalibTotalExposureNum: {$}", nTotalExposeNum);
  92. }
  93. else
  94. {
  95. FERROR("{$} file not exist!", strCalibDosePath);
  96. return false;
  97. }
  98. }
  99. catch (exception e)
  100. {
  101. FERROR("Get calib dose fail! reason:{$}", e.what());
  102. return false;
  103. }
  104. return true;
  105. }