DIOS.Dev.CollimatorMoudle.cpp 7.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346
  1. #include "stdafx.h"
  2. #include "DIOS.Dev.CollimatorMoudle.hpp"
  3. #include "DIOSDICOMInfo.h"
  4. using namespace DIOS::Dev;
  5. using namespace DIOS::Dev::Detail::Collimator;
  6. namespace nsColli = DIOS::Dev::Detail::Collimator;
  7. nsColli::CollimatorDevice::CollimatorDevice(std::shared_ptr <DIOS::Dev::IOEventCenter> EventCenter) :super(EventCenter)
  8. {
  9. m_EventCenter = EventCenter;
  10. m_nXSize = 0;
  11. m_nYSize = 0;
  12. m_nFilter = 0;
  13. m_nSID = 0;
  14. m_nAngle = 0;
  15. m_nMode = -1;
  16. }
  17. nsColli::CollimatorDevice::~CollimatorDevice()
  18. {
  19. }
  20. void nsColli::CollimatorDevice::FireNotify(string key, int value)
  21. {
  22. char szInfo[64] = { 0 };
  23. sprintf_s(szInfo, "%d", value);
  24. std::string str = szInfo;
  25. m_EventCenter->OnNotify(1, key, str);//(int)ATTRACTION_SET 2
  26. }
  27. void nsColli::CollimatorDevice::FireNotify(string key, string value)
  28. {
  29. std::string str = value;
  30. m_EventCenter->OnNotify(1, key, str);//(int)ATTRACTION_SET 2
  31. }
  32. void nsColli::CollimatorDevice::Register()
  33. {
  34. auto Disp = &Dispatch;
  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. int 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. int 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. int 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. int 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. int 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. int nParam = json[0];
  101. return SetCollimatorLight(nParam);
  102. }
  103. RET_STATUS CollimatorDevice::JSGetCollimatorXSize(std::string& out)
  104. {
  105. char szInfo[64] = { 0 };
  106. sprintf_s(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. sprintf_s(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. sprintf_s(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. sprintf_s(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. sprintf_s(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. sprintf_s(szInfo, "%d", m_nMode);
  142. out = szInfo;
  143. return RET_STATUS::RET_SUCCEED;
  144. }
  145. RET_STATUS CollimatorDevice::SetCollimatorSize(int xsize, int ysize)
  146. {
  147. return RET_STATUS::RET_SUCCEED;
  148. }
  149. RET_STATUS CollimatorDevice::SetCollimatorSID(int sid)
  150. {
  151. return RET_STATUS::RET_SUCCEED;
  152. }
  153. RET_STATUS CollimatorDevice::SetCollimatorFilter(int pParams)
  154. {
  155. return RET_STATUS::RET_SUCCEED;
  156. }
  157. RET_STATUS CollimatorDevice::SetCollimatorAngle(int pParams)
  158. {
  159. return RET_STATUS::RET_SUCCEED;
  160. }
  161. RET_STATUS CollimatorDevice::SetCollimatorMode(int Param)
  162. {
  163. return RET_STATUS::RET_SUCCEED;
  164. }
  165. RET_STATUS CollimatorDevice::SetCollimatorLight(int Param)
  166. {
  167. return RET_STATUS::RET_SUCCEED;
  168. }
  169. int CollimatorDevice::GetCollimatorXSize()
  170. {
  171. return m_nXSize;
  172. }
  173. int CollimatorDevice::GetCollimatorYSize()
  174. {
  175. return m_nYSize;
  176. }
  177. int CollimatorDevice::GetCollimatorSID()
  178. {
  179. return m_nSID;
  180. }
  181. int CollimatorDevice::GetCollimatorFilter()
  182. {
  183. return m_nFilter;
  184. }
  185. int CollimatorDevice::GetCollimatorAngle()
  186. {
  187. return m_nAngle;
  188. }
  189. int CollimatorDevice::GetCollimatorMode()
  190. {
  191. return m_nMode;
  192. }
  193. RET_STATUS CollimatorDevice::UpdateCollimatorXSize(int Param)
  194. {
  195. if (m_nXSize != Param)
  196. {
  197. m_nXSize = Param;
  198. FireNotify("XSize", Param);
  199. }
  200. return RET_STATUS::RET_SUCCEED;
  201. }
  202. RET_STATUS CollimatorDevice::UpdateCollimatorYSize(int Param)
  203. {
  204. if (m_nYSize != Param)
  205. {
  206. m_nYSize = Param;
  207. FireNotify("YSize", Param);
  208. }
  209. return RET_STATUS::RET_SUCCEED;
  210. }
  211. RET_STATUS CollimatorDevice::UpdateCollimatorSID(int Param)
  212. {
  213. if (m_nSID != Param)
  214. {
  215. m_nSID = Param;
  216. FireNotify("SID", Param);
  217. }
  218. return RET_STATUS::RET_SUCCEED;
  219. }
  220. RET_STATUS CollimatorDevice::UpdateCollimatorAngle(int Param)
  221. {
  222. if (m_nAngle != Param)
  223. {
  224. m_nAngle = Param;
  225. FireNotify("Angle", Param);
  226. }
  227. return RET_STATUS::RET_SUCCEED;
  228. }
  229. RET_STATUS CollimatorDevice::UpdateCollimatorFilter(int Param)
  230. {
  231. if (m_nFilter != Param)
  232. {
  233. m_nFilter = Param;
  234. FireNotify("Filter", Param);
  235. }
  236. return RET_STATUS::RET_SUCCEED;
  237. }
  238. RET_STATUS CollimatorDevice::UpdateCollimatorMode(int Param)
  239. {
  240. if (m_nMode != Param)
  241. {
  242. m_nMode = Param;
  243. FireNotify("Mode", Param);
  244. }
  245. return RET_STATUS::RET_SUCCEED;
  246. }
  247. void CollimatorDevice::ReportMessageToDicom()
  248. {
  249. FireNotify("XSize", m_nXSize);
  250. FireNotify("YSize", m_nYSize);
  251. FireNotify("SID", m_nSID);
  252. FireNotify("Angle", m_nAngle);
  253. FireNotify("Filter", m_nFilter);
  254. FireNotify("Mode", m_nMode);
  255. char strXY[48]{0};
  256. sprintf(strXY,"%03dx%03d", m_nXSize, m_nYSize);
  257. FireNotify("XYSize", strXY);
  258. }
  259. RET_STATUS CollimatorDevice::SetStudyInfo(ResDataObject & pParam)
  260. {
  261. return RET_STATUS::RET_SUCCEED;
  262. }
  263. RET_STATUS CollimatorDevice::SetTechParamsInfo(ResDataObject & pParam)
  264. {
  265. TECHPARAM_INFO info;
  266. info.SetVal(pParam.encode());
  267. string strcollimatorwidth = info.m_CollimatorWidth;
  268. string strcollimatorheight = info.m_CollimatorHeight;
  269. string strcollimatorfilter = info.m_CollimatorFilter;
  270. DWORD Width = 0;
  271. DWORD Height = 0;
  272. DWORD dwFilter = 0;
  273. if (strcollimatorwidth.find("IN") != string::npos)
  274. {
  275. Width = (DWORD)(atof(strcollimatorwidth.substr(0, strcollimatorwidth.size() - 2).c_str()) * 2.54);
  276. }
  277. else
  278. {
  279. Width = (DWORD)(atoi(strcollimatorwidth.substr(0, strcollimatorwidth.size() - 2).c_str()));
  280. }
  281. if (strcollimatorheight.find("IN") != string::npos)
  282. {
  283. Height = (DWORD)(atof(strcollimatorheight.substr(0, strcollimatorheight.size() - 2).c_str()) * 2.54);
  284. }
  285. else
  286. {
  287. Height = (DWORD)(atoi(strcollimatorheight.substr(0, strcollimatorheight.size() - 2).c_str()));
  288. }
  289. if (Width != 0 && Height != 0)
  290. {
  291. SetCollimatorSize(Width, Height);
  292. }
  293. dwFilter = (DWORD)atoi(strcollimatorfilter.c_str());
  294. if (dwFilter >= 0)
  295. {
  296. SetCollimatorFilter(dwFilter);
  297. }
  298. return RET_STATUS::RET_SUCCEED;
  299. }