CCOS.Dev.CollimatorMoudle.cpp 7.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310
  1. #include "CCOS.Dev.CollimatorMoudle.hpp"
  2. #include "CCOSDICOMInfo.h"
  3. using namespace CCOS::Dev;
  4. using namespace CCOS::Dev::Detail::Collimator;
  5. namespace nsColli = CCOS::Dev::Detail::Collimator;
  6. nsColli::CollimatorDevice::CollimatorDevice(std::shared_ptr <CCOS::Dev::IOEventCenter> EventCenter) :super(EventCenter)
  7. {
  8. m_EventCenter = EventCenter;
  9. m_nXSize = 0;
  10. m_nYSize = 0;
  11. m_nFilter = 0;
  12. m_nSID = 0;
  13. m_nAngle = 0;
  14. m_nMode = -1;
  15. }
  16. nsColli::CollimatorDevice::~CollimatorDevice()
  17. {
  18. }
  19. void nsColli::CollimatorDevice::FireNotify(string key, unsigned short value)
  20. {
  21. char szInfo[64] = { 0 };
  22. snprintf(szInfo, sizeof(szInfo), "%d", value);
  23. std::string str = szInfo;
  24. m_EventCenter->OnNotify(1, key, str); // (int)ATTRACTION_SET 2
  25. }
  26. void nsColli::CollimatorDevice::FireNotify(string key, string value)
  27. {
  28. std::string str = value;
  29. m_EventCenter->OnNotify(1, key, str);//(int)ATTRACTION_SET 2
  30. }
  31. void nsColli::CollimatorDevice::Register()
  32. {
  33. CCOS::Dev::Detail::Dispatch DispatchObj; // ¶¨Òå±äÁ¿
  34. auto Disp = &DispatchObj; // È¡±äÁ¿µØÖ·
  35. Disp->Action.Push("SetCollimatorSize", this, &nsColli::CollimatorDevice::JSSetCollimatorSize);
  36. Disp->Get.Push("Mode", this, &nsColli::CollimatorDevice::JSGetCollimatorMode);
  37. }
  38. bool nsColli::CollimatorDevice::Prepare()
  39. {
  40. Register();
  41. return true;
  42. }
  43. std::string nsColli::CollimatorDevice::GetGUID() const
  44. {
  45. return CollimatorUnitType;
  46. }
  47. RET_STATUS CollimatorDevice::JSSetStudyInfo(std::string in, std::string& out)
  48. {
  49. ResDataObject json;
  50. json.decode(in.c_str());
  51. return SetStudyInfo(json);
  52. }
  53. RET_STATUS CollimatorDevice::JSSetTechParamsInfo(std::string in, std::string& out)
  54. {
  55. ResDataObject json;
  56. json.decode(in.c_str());
  57. return SetTechParamsInfo(json);
  58. }
  59. RET_STATUS CollimatorDevice::JSSetCollimatorSize(std::string in, std::string& out)
  60. {
  61. ResDataObject json;
  62. json.decode(in.c_str());
  63. unsigned short xsize, ysize;
  64. xsize = json[0];
  65. ysize = json[1];
  66. return SetCollimatorSize(xsize, ysize);
  67. }
  68. RET_STATUS CollimatorDevice::JSSetCollimatorSID(std::string in, std::string& out)
  69. {
  70. ResDataObject json;
  71. json.decode(in.c_str());
  72. unsigned short nParam = json[0];
  73. return SetCollimatorSID(nParam);
  74. }
  75. RET_STATUS CollimatorDevice::JSSetCollimatorFilter(std::string in, std::string& out)
  76. {
  77. ResDataObject json;
  78. json.decode(in.c_str());
  79. unsigned short nParam = json[0];
  80. return SetCollimatorFilter(nParam);
  81. }
  82. RET_STATUS CollimatorDevice::JSSetCollimatorAngle(std::string in, std::string& out)
  83. {
  84. ResDataObject json;
  85. json.decode(in.c_str());
  86. unsigned short nParam = json[0];
  87. return SetCollimatorAngle(nParam);
  88. }
  89. RET_STATUS CollimatorDevice::JSSetCollimatorMode(std::string in, std::string& out)
  90. {
  91. ResDataObject json;
  92. json.decode(in.c_str());
  93. unsigned short nParam = json[0];
  94. return SetCollimatorMode(nParam);
  95. }
  96. RET_STATUS CollimatorDevice::JSSetCollimatorLight(std::string in, std::string& out)
  97. {
  98. ResDataObject json;
  99. json.decode(in.c_str());
  100. unsigned short nParam = json[0];
  101. return SetCollimatorLight(nParam);
  102. }
  103. RET_STATUS CollimatorDevice::JSGetCollimatorXSize(std::string& out)
  104. {
  105. char szInfo[64] = { 0 };
  106. snprintf(szInfo, sizeof(szInfo), "%d", m_nXSize);
  107. out = szInfo;
  108. return RET_STATUS::RET_SUCCEED;
  109. }
  110. RET_STATUS CollimatorDevice::JSGetCollimatorYSize(std::string& out)
  111. {
  112. char szInfo[64] = { 0 };
  113. snprintf(szInfo, sizeof(szInfo), "%d", m_nYSize);
  114. out = szInfo;
  115. return RET_STATUS::RET_SUCCEED;
  116. }
  117. RET_STATUS CollimatorDevice::JSGetCollimatorSID(std::string& out)
  118. {
  119. char szInfo[64] = { 0 };
  120. snprintf(szInfo, sizeof(szInfo), "%d", m_nSID);
  121. out = szInfo;
  122. return RET_STATUS::RET_SUCCEED;
  123. }
  124. RET_STATUS CollimatorDevice::JSGetCollimatorFilter(std::string& out)
  125. {
  126. char szInfo[64] = { 0 };
  127. snprintf(szInfo, sizeof(szInfo), "%d", m_nFilter);
  128. out = szInfo;
  129. return RET_STATUS::RET_SUCCEED;
  130. }
  131. RET_STATUS CollimatorDevice::JSGetCollimatorAngle(std::string& out)
  132. {
  133. char szInfo[64] = { 0 };
  134. snprintf(szInfo, sizeof(szInfo), "%d", m_nAngle);
  135. out = szInfo;
  136. return RET_STATUS::RET_SUCCEED;
  137. }
  138. RET_STATUS CollimatorDevice::JSGetCollimatorMode(std::string& out)
  139. {
  140. char szInfo[64] = { 0 };
  141. snprintf(szInfo, sizeof(szInfo), "%d", m_nMode);
  142. out = szInfo;
  143. return RET_STATUS::RET_SUCCEED;
  144. }
  145. RET_STATUS CollimatorDevice::SetCollimatorSize(unsigned short xsize, unsigned short ysize)
  146. {
  147. return RET_STATUS::RET_SUCCEED;
  148. }
  149. RET_STATUS CollimatorDevice::SetCollimatorSID(unsigned short sid)
  150. {
  151. return RET_STATUS::RET_SUCCEED;
  152. }
  153. RET_STATUS CollimatorDevice::SetCollimatorFilter(unsigned short pParams)
  154. {
  155. return RET_STATUS::RET_SUCCEED;
  156. }
  157. RET_STATUS CollimatorDevice::SetCollimatorAngle(unsigned short pParams)
  158. {
  159. return RET_STATUS::RET_SUCCEED;
  160. }
  161. RET_STATUS CollimatorDevice::SetCollimatorMode(unsigned short Param)
  162. {
  163. return RET_STATUS::RET_SUCCEED;
  164. }
  165. RET_STATUS CollimatorDevice::SetCollimatorLight(unsigned short Param)
  166. {
  167. return RET_STATUS::RET_SUCCEED;
  168. }
  169. RET_STATUS CollimatorDevice::UpdateCollimatorXSize(unsigned short Param)
  170. {
  171. m_nXSize = Param;
  172. FireNotify("XSize", Param);
  173. return RET_STATUS::RET_SUCCEED;
  174. }
  175. RET_STATUS CollimatorDevice::UpdateCollimatorYSize(unsigned short Param)
  176. {
  177. m_nYSize = Param;
  178. FireNotify("YSize", Param);
  179. return RET_STATUS::RET_SUCCEED;
  180. }
  181. RET_STATUS CollimatorDevice::UpdateCollimatorSID(unsigned short Param)
  182. {
  183. m_nSID = Param;
  184. FireNotify("SID", Param);
  185. return RET_STATUS::RET_SUCCEED;
  186. }
  187. RET_STATUS CollimatorDevice::UpdateCollimatorAngle(unsigned short Param)
  188. {
  189. m_nAngle = Param;
  190. FireNotify("Angle", Param);
  191. return RET_STATUS::RET_SUCCEED;
  192. }
  193. RET_STATUS CollimatorDevice::UpdateCollimatorFilter(unsigned short Param)
  194. {
  195. m_nFilter = Param;
  196. FireNotify("Filter", Param);
  197. return RET_STATUS::RET_SUCCEED;
  198. }
  199. RET_STATUS CollimatorDevice::UpdateCollimatorMode(unsigned short Param)
  200. {
  201. m_nMode = Param;
  202. FireNotify("Mode", Param);
  203. return RET_STATUS::RET_SUCCEED;
  204. }
  205. void CollimatorDevice::ReportMessageToDicom()
  206. {
  207. FireNotify("XSize", m_nXSize);
  208. FireNotify("YSize", m_nYSize);
  209. FireNotify("SID", m_nSID);
  210. FireNotify("Angle", m_nAngle);
  211. FireNotify("Filter", m_nFilter);
  212. if (m_nFilter == 1)
  213. {
  214. FireNotify("StrFilter", "Mo");
  215. }
  216. else
  217. {
  218. FireNotify("StrFilter", "Rh");
  219. }
  220. FireNotify("Mode", m_nMode);
  221. char strXY[48]{ 0 };
  222. sprintf(strXY, "%03d,%03d", m_nXSize, m_nYSize);
  223. FireNotify("XYSize", strXY);
  224. }
  225. RET_STATUS CollimatorDevice::SetStudyInfo(ResDataObject & pParam)
  226. {
  227. return RET_STATUS::RET_SUCCEED;
  228. }
  229. RET_STATUS CollimatorDevice::SetTechParamsInfo(ResDataObject & pParam)
  230. {
  231. TECHPARAM_INFO info;
  232. info.SetVal(pParam.encode());
  233. string strcollimatorwidth = info.m_CollimatorWidth;
  234. string strcollimatorheight = info.m_CollimatorHeight;
  235. string strcollimatorfilter = info.m_CollimatorFilter;
  236. unsigned long Width = 0;
  237. unsigned long Height = 0;
  238. unsigned long dwFilter = 0;
  239. if (strcollimatorwidth.find("IN") != string::npos)
  240. {
  241. Width = (unsigned long)(atof(strcollimatorwidth.substr(0, strcollimatorwidth.size() - 2).c_str()) * 2.54);
  242. }
  243. else
  244. {
  245. Width = (unsigned long)(atoi(strcollimatorwidth.substr(0, strcollimatorwidth.size() - 2).c_str()));
  246. }
  247. if (strcollimatorheight.find("IN") != string::npos)
  248. {
  249. Height = (unsigned long)(atof(strcollimatorheight.substr(0, strcollimatorheight.size() - 2).c_str()) * 2.54);
  250. }
  251. else
  252. {
  253. Height = (unsigned long)(atoi(strcollimatorheight.substr(0, strcollimatorheight.size() - 2).c_str()));
  254. }
  255. if (Width != 0 && Height != 0)
  256. {
  257. SetCollimatorSize(Width, Height);
  258. }
  259. dwFilter = (unsigned long)atoi(strcollimatorfilter.c_str());
  260. if (dwFilter >= 0)
  261. {
  262. SetCollimatorFilter(dwFilter);
  263. }
  264. return RET_STATUS::RET_SUCCEED;
  265. }