BatteryMould.hpp 4.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187
  1. #pragma once
  2. #include <memory>
  3. #include "ResDataObject.h"
  4. #include "CCOS.Dev.IODevice.hpp"
  5. #include "CCOS.Dev.MouldDefine.hpp"
  6. #include "Detector_Model_Def.h"
  7. namespace CCOS::Dev::Detail
  8. {
  9. class DeviceBatteryMould : public IntMouldWithWarn
  10. {
  11. typedef enum ECOM_Battery_state
  12. {
  13. ECOM_BAT_STATE_TOO_LOW = 0,
  14. ECOM_BAT_STATE_LOW,
  15. ECOM_BAT_STAE_NORMAL,
  16. ECOM_BAT_STATE_GOOD,
  17. ECOM_BAT_STATE_FULL
  18. }ECOM_BATTERY_STATE;
  19. int m_RemainPowerValue;
  20. std::shared_ptr <CCOS::Dev::IOEventCenter> m_EventCenter;
  21. std::string m_Key;
  22. public:
  23. using super = IntMouldWithWarn;
  24. DeviceBatteryMould(const char* strkey, int initialvalue, int min,
  25. int WarnMin, int WarnMax, int CalibWarnMin, int CalibWarnMax,
  26. int max, int accuracy, std::shared_ptr <CCOS::Dev::IOEventCenter> EventCenter)
  27. :super(strkey, initialvalue, min, WarnMin, WarnMax, CalibWarnMin, CalibWarnMax, max, accuracy)
  28. {
  29. m_Key = strkey;
  30. m_EventCenter = EventCenter;
  31. m_RemainPowerValue = 0;
  32. }
  33. ~DeviceBatteryMould() {}
  34. std::string GetDescription()
  35. {
  36. ResDataObject temp, result;
  37. temp.add(ValKey::UPPERLIMIT, m_LimitMax);
  38. temp.add(ValKey::LOWERLIMIT, m_LimitMin);
  39. temp.add(ValKey::WARNUPPERLIMIT, m_WarningMax);
  40. temp.add(ValKey::WARNLOWERLIMIT, m_WarningMin);
  41. temp.add(ValKey::ACCURACY, m_Accuracy);
  42. temp.add(ValKey::UNIT, m_Key.c_str());
  43. result.add(Key.c_str(), temp);
  44. return result.encode();
  45. }
  46. RET_STATUS JSGetCurrentBatteryValue(std::string & out)
  47. {
  48. char szFDinfo[MAX_STRING] = { 0 };
  49. sprintf(szFDinfo, "%d", m_RemainPowerValue);
  50. out = szFDinfo;
  51. return RET_STATUS::RET_SUCCEED;
  52. }
  53. bool SetRemainPowerValue(int nValue, int & nStatus)
  54. {
  55. m_RemainPowerValue = nValue;
  56. if (m_WarningMin <= nValue)
  57. {
  58. nStatus = ECOM_BAT_STAE_NORMAL;
  59. }
  60. else if (m_LimitMin <= nValue && nValue < m_WarningMin)
  61. {
  62. nStatus = ECOM_BAT_STATE_LOW;
  63. }
  64. else if (nValue < m_LimitMin)
  65. {
  66. nStatus = ECOM_BAT_STATE_TOO_LOW;
  67. }
  68. char szFDinfo[MAX_STRING] = { 0 };
  69. sprintf(szFDinfo, "%d", nValue);
  70. m_EventCenter->OnNotify((int)ATTRACTION_SET, "Remain_Power_Value", szFDinfo);
  71. return true;
  72. }
  73. RET_STATUS JSGetBatteryWarningMin(std::string& out)
  74. {
  75. char szFDinfo[MAX_STRING] = { 0 };
  76. sprintf(szFDinfo, "%d", m_WarningMin);
  77. out = szFDinfo;
  78. return RET_STATUS::RET_SUCCEED;
  79. }
  80. RET_STATUS JSGetBatteryErrorMin(std::string& out)
  81. {
  82. char szFDinfo[MAX_STRING] = { 0 };
  83. sprintf(szFDinfo, "%d", m_ErrorMin);
  84. out = szFDinfo;
  85. return RET_STATUS::RET_SUCCEED;
  86. }
  87. RET_STATUS SetBatteryWarningMin(string nValue)
  88. {
  89. int temp = atoi(nValue.c_str());
  90. if (m_WarningMin == temp)
  91. {
  92. return RET_STATUS::RET_SUCCEED;
  93. }
  94. m_WarningMin = temp;
  95. char szFDinfo[MAX_STRING] = { 0 };
  96. sprintf(szFDinfo, "%d", m_WarningMin);
  97. m_EventCenter->OnNotify((int)ATTRACTION_SET, "BatLowerLimit", szFDinfo);
  98. return RET_STATUS::RET_SUCCEED;
  99. }
  100. RET_STATUS SetBatteryErrorMin(string nValue)
  101. {
  102. int temp = atoi(nValue.c_str());
  103. if (m_ErrorMin == temp)
  104. {
  105. return RET_STATUS::RET_SUCCEED;
  106. }
  107. m_ErrorMin = temp;
  108. char szFDinfo[MAX_STRING] = { 0 };
  109. sprintf(szFDinfo, "%d", m_ErrorMin);
  110. m_EventCenter->OnNotify((int)ATTRACTION_SET, "BatMiniLimit", szFDinfo);
  111. return RET_STATUS::RET_SUCCEED;
  112. }
  113. RET_STATUS JSGetBatteryCalibWarningMin(std::string& out)
  114. {
  115. char szFDinfo[MAX_STRING] = { 0 };
  116. sprintf(szFDinfo, "%d", m_CalibWarningMin);
  117. out = szFDinfo;
  118. return RET_STATUS::RET_SUCCEED;
  119. }
  120. bool SetBatteryCalibWarningMin(int nValue)
  121. {
  122. if (m_CalibWarningMin == nValue)
  123. {
  124. return true;
  125. }
  126. m_CalibWarningMin = nValue;
  127. char szFDinfo[MAX_STRING] = { 0 };
  128. sprintf(szFDinfo, "%d", nValue);
  129. m_EventCenter->OnNotify((int)ATTRACTION_SET, "BatLowerLimitInCali", szFDinfo);
  130. return true;
  131. }
  132. RET_STATUS SetBatLowerLimitInCalib(string nValue)
  133. {
  134. int temp = atoi(nValue.c_str());
  135. if (m_CalibWarningMin == temp)
  136. {
  137. return RET_STATUS::RET_SUCCEED;
  138. }
  139. m_CalibWarningMin = temp;
  140. char szFDinfo[MAX_STRING] = { 0 };
  141. sprintf(szFDinfo, "%d", m_CalibWarningMin);
  142. m_EventCenter->OnNotify((int)ATTRACTION_SET, "BatLowerLimitInCali", szFDinfo);
  143. return RET_STATUS::RET_SUCCEED;
  144. }
  145. RET_STATUS JSUpdateBatteryWarningMin(string in, string& out)
  146. {
  147. out = in;
  148. return SetBatteryWarningMin(in);
  149. }
  150. RET_STATUS JSUpdateBatteryErrorMin(string in, string& out)
  151. {
  152. out = in;
  153. return SetBatteryErrorMin(in);
  154. }
  155. RET_STATUS JSUpdateBatLowerLimitInCalib(string in, string& out)
  156. {
  157. out = in;
  158. return SetBatLowerLimitInCalib(in);
  159. }
  160. };//DeviceBatteryMould
  161. }