TemperatureMould.hpp 7.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274
  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 ZSKK_Templerature_state
  11. {
  12. ZSKK_TEM_STATE_TOO_LOW = 0,
  13. ZSKK_TEM_STATE_LOW,
  14. ZSKK_TEM_STAE_NORMAL,
  15. ZSKK_TEM_STATE_HIGH,
  16. ZSKK_TEM_STATE_TOO_HIGH
  17. }ZSKK_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_s(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_s(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_s(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_s(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_s(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_s(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_s(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_s(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_s(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_s(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_s(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_s(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_s(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. if (nValue != m_CurrentValue)
  181. {
  182. m_CurrentValue = nValue;
  183. if (m_CurrentValue > m_LimitMax)
  184. {
  185. nState = ZSKK_TEM_STATE_TOO_HIGH;
  186. }
  187. else if (m_CurrentValue <= m_LimitMax && m_CurrentValue > m_WarningMax)
  188. {
  189. nState = ZSKK_TEM_STATE_HIGH;
  190. }
  191. else if (m_CurrentValue <= m_WarningMax && m_CurrentValue >= m_WarningMin)
  192. {
  193. nState = ZSKK_TEM_STAE_NORMAL;
  194. }
  195. else if (m_CurrentValue < m_WarningMin && m_CurrentValue >= m_LimitMin)
  196. {
  197. nState = ZSKK_TEM_STATE_LOW;
  198. }
  199. else if (m_CurrentValue < m_LimitMin)
  200. {
  201. nState = ZSKK_TEM_STATE_TOO_LOW;
  202. }
  203. char szFDinfo[MAX_STRING] = { 0 };
  204. sprintf_s(szFDinfo, "%f", nValue);
  205. m_EventCenter->OnNotify((int)ATTRACTION_SET,"Temperature_Value", szFDinfo);
  206. }
  207. return true;
  208. }
  209. RET_STATUS JSUpdateTemperatureWarningMax(string in,string& out)
  210. {
  211. out = in;
  212. return SetTemperatureWarningMax(in);
  213. }
  214. RET_STATUS JSUpdateTemperatureWarningMin(string in, string& out)
  215. {
  216. out = in;
  217. return SetTemperatureWarningMin(in);
  218. }
  219. RET_STATUS JSUpdateTemperatureErrorMax(string in, string& out)
  220. {
  221. out = in;
  222. return SetTemperatureErrorMax(in);
  223. }
  224. RET_STATUS JSUpdateTemperatureErrorMin(string in, string& out)
  225. {
  226. out = in;
  227. return SetTemperatureErrorMin(in);
  228. }
  229. RET_STATUS JSUpdateTemperatureCalibWarningMax(string in, string& out)
  230. {
  231. out = in;
  232. return SetTemperatureCalibWarningMax(in);
  233. }
  234. RET_STATUS JSUpdateTemperatureCalibWarningMin(string in, string& out)
  235. {
  236. out = in;
  237. return SetTemperatureCalibWarningMin(in);
  238. }
  239. };//DeviceTemperatureMould
  240. }