TemperatureMould.hpp 6.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271
  1. #pragma once
  2. #include <memory>
  3. #include "ResDataObject.h"
  4. #include "CCOS.Dev.IODevice.hpp"
  5. #include "CCOS.Dev.MouldDefine.hpp"
  6. namespace CCOS::Dev::Detail
  7. {
  8. class DeviceTemperatureMould : public FloatMouldWithWarn
  9. {
  10. typedef enum ECOM_Templerature_state
  11. {
  12. ECOM_TEM_STATE_TOO_LOW = 0,
  13. ECOM_TEM_STATE_LOW,
  14. ECOM_TEM_STAE_NORMAL,
  15. ECOM_TEM_STATE_HIGH,
  16. ECOM_TEM_STATE_TOO_HIGH
  17. }ECOM_TEMPERATURE_STATE;
  18. float m_CurrentValue;
  19. std::shared_ptr <CCOS::Dev::IOEventCenter> m_EventCenter;
  20. std::string m_Key;
  21. public:
  22. using super = FloatMouldWithWarn;
  23. DeviceTemperatureMould(const char* strkey, float initialvalue, float min, float WarnMin,
  24. float WarnMax, float CalibWarnMin, float CalibWarnMax, float max, float accuracy,
  25. std::shared_ptr <CCOS::Dev::IOEventCenter> EventCenter)
  26. : super(strkey, initialvalue, min, WarnMin, WarnMax, CalibWarnMin, CalibWarnMax, max, accuracy)
  27. {
  28. m_Key = strkey;
  29. m_EventCenter = EventCenter;
  30. m_CurrentValue = initialvalue;
  31. m_WarningMax = WarnMax;
  32. m_WarningMin = WarnMin;
  33. m_CalibWarningMax = CalibWarnMax;
  34. m_CalibWarningMin = CalibWarnMin;
  35. m_ErrorMax = max;
  36. m_ErrorMin = min;
  37. }
  38. ~DeviceTemperatureMould() {}
  39. std::string GetDescription()
  40. {
  41. ResDataObject temp, result;
  42. temp.add(ValKey::UPPERLIMIT, m_LimitMax);
  43. temp.add(ValKey::LOWERLIMIT, m_LimitMin);
  44. temp.add(ValKey::WARNUPPERLIMIT, m_WarningMax);
  45. temp.add(ValKey::WARNLOWERLIMIT, m_WarningMin);
  46. temp.add(ValKey::ACCURACY, m_Accuracy);
  47. temp.add(ValKey::UNIT, m_Key.c_str());
  48. result.add(Key.c_str(), temp);
  49. return result.encode();
  50. }
  51. RET_STATUS JSGetCurrentTemperatureValue(std::string & out)
  52. {
  53. char szFDinfo[MAX_STRING] = { 0 };
  54. sprintf(szFDinfo, "%f", m_CurrentValue);
  55. out = szFDinfo;
  56. return RET_STATUS::RET_SUCCEED;
  57. }
  58. RET_STATUS JSGetTemperatureWarningMax(std::string & out)
  59. {
  60. char szFDinfo[MAX_STRING] = { 0 };
  61. sprintf(szFDinfo, "%f", m_WarningMax);
  62. out = szFDinfo;
  63. return RET_STATUS::RET_SUCCEED;
  64. }
  65. RET_STATUS JSGetTemperatureWarningMin(std::string & out)
  66. {
  67. char szFDinfo[MAX_STRING] = { 0 };
  68. sprintf(szFDinfo, "%f", m_WarningMin);
  69. out = szFDinfo;
  70. return RET_STATUS::RET_SUCCEED;
  71. }
  72. RET_STATUS JSGetTemperatureCalibWarningMax(std::string & out)
  73. {
  74. char szFDinfo[MAX_STRING] = { 0 };
  75. sprintf(szFDinfo, "%f", m_CalibWarningMax);
  76. out = szFDinfo;
  77. return RET_STATUS::RET_SUCCEED;
  78. }
  79. RET_STATUS JSGetTemperatureCalibWarningMin(std::string & out)
  80. {
  81. char szFDinfo[MAX_STRING] = { 0 };
  82. sprintf(szFDinfo, "%f", m_CalibWarningMin);
  83. out = szFDinfo;
  84. return RET_STATUS::RET_SUCCEED;
  85. }
  86. RET_STATUS JSGetTemperatureErrorMax(std::string & out)
  87. {
  88. char szFDinfo[MAX_STRING] = { 0 };
  89. sprintf(szFDinfo, "%f", m_ErrorMax);
  90. out = szFDinfo;
  91. return RET_STATUS::RET_SUCCEED;
  92. }
  93. RET_STATUS JSGetTemperatureErrorMin(std::string & out)
  94. {
  95. char szFDinfo[MAX_STRING] = { 0 };
  96. sprintf(szFDinfo, "%f", m_ErrorMin);
  97. out = szFDinfo;
  98. return RET_STATUS::RET_SUCCEED;
  99. }
  100. RET_STATUS SetTemperatureWarningMax(string strValue)
  101. {
  102. float temp = stof(strValue);
  103. if (m_WarningMax == temp)
  104. {
  105. return RET_STATUS::RET_SUCCEED;
  106. }
  107. m_WarningMax = temp;
  108. char szFDinfo[MAX_STRING] = { 0 };
  109. sprintf(szFDinfo, "%f", m_WarningMax);
  110. m_EventCenter->OnNotify((int)ATTRACTION_SET, "TempUpperLimit", szFDinfo);
  111. return RET_STATUS::RET_SUCCEED;
  112. }
  113. RET_STATUS SetTemperatureWarningMin(string strValue)
  114. {
  115. float temp = stof(strValue);
  116. if (m_WarningMin == temp)
  117. {
  118. return RET_STATUS::RET_SUCCEED;
  119. }
  120. m_WarningMin = temp;
  121. char szFDinfo[MAX_STRING] = { 0 };
  122. sprintf(szFDinfo, "%f", m_WarningMin);
  123. m_EventCenter->OnNotify((int)ATTRACTION_SET, "TempLowerLimit", szFDinfo);
  124. return RET_STATUS::RET_SUCCEED;
  125. }
  126. RET_STATUS SetTemperatureCalibWarningMax(string strValue)
  127. {
  128. float temp = stof(strValue);
  129. if (m_CalibWarningMax == temp)
  130. {
  131. return RET_STATUS::RET_SUCCEED;
  132. }
  133. m_CalibWarningMax = temp;
  134. char szFDinfo[MAX_STRING] = { 0 };
  135. sprintf(szFDinfo, "%f", m_CalibWarningMax);
  136. m_EventCenter->OnNotify((int)ATTRACTION_SET, "TemperatureCalibUpWarn", szFDinfo);
  137. return RET_STATUS::RET_SUCCEED;
  138. }
  139. RET_STATUS SetTemperatureCalibWarningMin(string strValue)
  140. {
  141. float temp = stof(strValue);
  142. if (m_CalibWarningMin == temp)
  143. {
  144. return RET_STATUS::RET_SUCCEED;
  145. }
  146. m_CalibWarningMin = temp;
  147. char szFDinfo[MAX_STRING] = { 0 };
  148. sprintf(szFDinfo, "%f", m_CalibWarningMin);
  149. m_EventCenter->OnNotify((int)ATTRACTION_SET, "TemperatureCalibLowWarn", szFDinfo);
  150. return RET_STATUS::RET_SUCCEED;
  151. }
  152. RET_STATUS SetTemperatureErrorMax(string strValue)
  153. {
  154. float temp = stof(strValue);
  155. if (m_ErrorMax == temp)
  156. {
  157. return RET_STATUS::RET_SUCCEED;
  158. }
  159. m_ErrorMax = temp;
  160. char szFDinfo[MAX_STRING] = { 0 };
  161. sprintf(szFDinfo, "%f", m_ErrorMax);
  162. m_EventCenter->OnNotify((int)ATTRACTION_SET, "TempMaxLimit", szFDinfo);
  163. return RET_STATUS::RET_SUCCEED;
  164. }
  165. RET_STATUS SetTemperatureErrorMin(string strValue)
  166. {
  167. float temp = stof(strValue);
  168. if (m_ErrorMin == temp)
  169. {
  170. return RET_STATUS::RET_SUCCEED;
  171. }
  172. m_ErrorMin = temp;
  173. char szFDinfo[MAX_STRING] = { 0 };
  174. sprintf(szFDinfo, "%f", m_ErrorMin);
  175. m_EventCenter->OnNotify((int)ATTRACTION_SET, "TempMinLimit", szFDinfo);
  176. return RET_STATUS::RET_SUCCEED;
  177. }
  178. bool SetTemperature(float nValue, int & nState)
  179. {
  180. m_CurrentValue = nValue;
  181. if (m_CurrentValue > m_LimitMax)
  182. {
  183. nState = ECOM_TEM_STATE_TOO_HIGH;
  184. }
  185. else if (m_CurrentValue <= m_LimitMax && m_CurrentValue > m_WarningMax)
  186. {
  187. nState = ECOM_TEM_STATE_HIGH;
  188. }
  189. else if (m_CurrentValue <= m_WarningMax && m_CurrentValue >= m_WarningMin)
  190. {
  191. nState = ECOM_TEM_STAE_NORMAL;
  192. }
  193. else if (m_CurrentValue < m_WarningMin && m_CurrentValue >= m_LimitMin)
  194. {
  195. nState = ECOM_TEM_STATE_LOW;
  196. }
  197. else if (m_CurrentValue < m_LimitMin)
  198. {
  199. nState = ECOM_TEM_STATE_TOO_LOW;
  200. }
  201. char szFDinfo[MAX_STRING] = { 0 };
  202. sprintf(szFDinfo, "%f", nValue);
  203. m_EventCenter->OnNotify((int)ATTRACTION_SET, "Temperature_Value", szFDinfo);
  204. return true;
  205. }
  206. RET_STATUS JSUpdateTemperatureWarningMax(string in,string& out)
  207. {
  208. out = in;
  209. return SetTemperatureWarningMax(in);
  210. }
  211. RET_STATUS JSUpdateTemperatureWarningMin(string in, string& out)
  212. {
  213. out = in;
  214. return SetTemperatureWarningMin(in);
  215. }
  216. RET_STATUS JSUpdateTemperatureErrorMax(string in, string& out)
  217. {
  218. out = in;
  219. return SetTemperatureErrorMax(in);
  220. }
  221. RET_STATUS JSUpdateTemperatureErrorMin(string in, string& out)
  222. {
  223. out = in;
  224. return SetTemperatureErrorMin(in);
  225. }
  226. RET_STATUS JSUpdateTemperatureCalibWarningMax(string in, string& out)
  227. {
  228. out = in;
  229. return SetTemperatureCalibWarningMax(in);
  230. }
  231. RET_STATUS JSUpdateTemperatureCalibWarningMin(string in, string& out)
  232. {
  233. out = in;
  234. return SetTemperatureCalibWarningMin(in);
  235. }
  236. };//DeviceTemperatureMould
  237. }