DIOS.Dev.FPD.CalibUnit.cpp 11 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486
  1. // CCOS.Dev.FPD.DEMO.cpp : 定义 DLL 应用程序的导出函数。
  2. //
  3. #include "stdafx.h"
  4. #include "CCOS.Dev.FPDDeviceMould.hpp"
  5. using namespace CCOS::Dev;
  6. using namespace CCOS::Dev::Detail::Detector;
  7. namespace nsFPD = CCOS::Dev::Detail::Detector;
  8. extern Log4CPP::Logger* gLogger;
  9. //-----------------------------------------------------------------------------
  10. // CalibUnit
  11. //-----------------------------------------------------------------------------
  12. nsFPD::CalibUnit::CalibUnit()
  13. {
  14. m_CurrentCalibType = CCOS_CALIBRATION_TYPE_NONE;
  15. m_CalibStatus = CCOS_CALIBRATION_STATUS_MAX;
  16. m_strCalibProgress = "0";
  17. m_strUploadCalibrationFilesResult = "0";
  18. m_strSaveCalibrationFileFinish = "0";
  19. }
  20. nsFPD::CalibUnit:: ~CalibUnit()
  21. {
  22. }
  23. void OEM_IF nsFPD::CalibUnit::SetEventCenter(std::shared_ptr <CCOS::Dev::IOEventCenter> EventCenter)
  24. {
  25. m_EventCenter = EventCenter;
  26. }
  27. RET_STATUS nsFPD::CalibUnit::JSSetSID(std::string in, std::string& out)
  28. {
  29. Info("JSSetSID. {$}", in.c_str());
  30. ResDataObject json;
  31. json.decode(in.c_str());
  32. int mode = json[0];
  33. return SetSID(mode);
  34. }
  35. RET_STATUS nsFPD::CalibUnit::JSActiveCalibration(std::string in, std::string & out)
  36. {
  37. ResDataObject json;
  38. json.decode(in.c_str());
  39. int mode = json[0];
  40. Info("JSActiveCalibration. {$}", in.c_str());
  41. Info("Calibrationtype is {$}", mode);
  42. out = "test@ActiveCalibration";
  43. CCOS_CALIBRATION_TYPE type = CCOS_CALIBRATION_TYPE_NONE;
  44. if (mode == CCOS_CALIBRATION_TYPE_DARK)
  45. {
  46. type = CCOS_CALIBRATION_TYPE_DARK;
  47. }
  48. else if (mode == CCOS_CALIBRATION_TYPE_XRAY)
  49. {
  50. type = CCOS_CALIBRATION_TYPE_XRAY;
  51. }
  52. RET_STATUS bret = ActiveCalibration(type);
  53. if (RET_STATUS::RET_SUCCEED == bret)
  54. {
  55. m_CurrentCalibType = type;
  56. }
  57. return bret;
  58. }
  59. RET_STATUS nsFPD::CalibUnit::JSGetRequestedDose(std::string in, std::string& out)
  60. {
  61. Info("JSGetRequestedDose");
  62. string strDoseInfo = "";
  63. RET_STATUS bret = GetRequestedDose(strDoseInfo);
  64. if (RET_STATUS::RET_SUCCEED == bret)
  65. {
  66. out = strDoseInfo;
  67. }
  68. return bret;
  69. }
  70. RET_STATUS nsFPD::CalibUnit::JSSetRequestedDose(std::string in, std::string& out)
  71. {
  72. Info("JSSetRequestedDose. \n{$}", in.c_str());
  73. RET_STATUS nRet = SetRequestedDose(in);
  74. return nRet;
  75. }
  76. RET_STATUS nsFPD::CalibUnit::SetRequestedDose(std::string in)
  77. {
  78. return RET_STATUS::RET_SUCCEED;
  79. }
  80. RET_STATUS nsFPD::CalibUnit::JSPrepareCalibration(std::string in, std::string& out)
  81. {
  82. Info("JSPrepareCalibration.");
  83. return PrepareCalibration();
  84. }
  85. RET_STATUS nsFPD::CalibUnit::JSStartCalibration(std::string in, std::string& out)
  86. {
  87. Info("JSStartCalibration.");
  88. return StartCalibration();
  89. }
  90. RET_STATUS CCOS::Dev::Detail::Detector::CalibUnit::JSStartOffset(std::string in, std::string& out)
  91. {
  92. Info("JSStartOffset.");
  93. ResDataObject json;
  94. json.decode(in.c_str());
  95. Info("JSStartOffset. {$}", in.c_str());
  96. if (json.GetFirstOf("P0") < 0)
  97. {
  98. return RET_STATUS::RET_FAILED;
  99. }
  100. string strMode = json["P0"];
  101. bool bisAll = atoi(strMode.c_str());
  102. return StartOffset(bisAll);
  103. }
  104. RET_STATUS CCOS::Dev::Detail::Detector::CalibUnit::JSAbortOffset(std::string in, std::string& out)
  105. {
  106. Info("JSAbortOffset.");
  107. return AbortOffset();
  108. }
  109. RET_STATUS OEM_IF nsFPD::CalibUnit::PauseCalibration()
  110. {
  111. Info("PauseCalibration.");
  112. return RET_STATUS::RET_SUCCEED;
  113. }
  114. RET_STATUS nsFPD::CalibUnit::JSStopCalibration(std::string in, std::string& out)
  115. {
  116. Info("JSStopCalibration.");
  117. return StopCalibration();
  118. }
  119. RET_STATUS nsFPD::CalibUnit::JSSetCorrectionType(std::string in, std::string & out)
  120. {
  121. return RET_STATUS::RET_SUCCEED;
  122. }
  123. RET_STATUS nsFPD::CalibUnit::JSGetCalibStatus(std::string & out)
  124. {
  125. auto szFDinfo = std::to_string(m_CalibStatus);
  126. out = szFDinfo;
  127. return RET_STATUS::RET_SUCCEED;
  128. }
  129. RET_STATUS nsFPD::CalibUnit::SetCalibrationStatus(string in)
  130. {
  131. Info("SetCalibrationStatus in:{$}", in);
  132. if (in == "")
  133. {
  134. return RET_STATUS::RET_FAILED;
  135. }
  136. int nCalibrationStatus = atoi(in.c_str());
  137. string strTemp = "";
  138. switch (nCalibrationStatus)
  139. {
  140. case CCOS_CALIBRATION_STATUS_ERROR:
  141. strTemp = "ZSKK_FPD_STATE_ERROR";
  142. break;
  143. case CCOS_CALIBRATION_STATUS_STANDBY:
  144. strTemp = "ZSKK_FPD_STATE_STANDBY";
  145. break;
  146. case CCOS_CALIBRATION_STATUS_ACTIVE:
  147. strTemp = "ZSKK_FPD_STATE_ACTIVE";
  148. break;
  149. case CCOS_CALIBRATION_STATUS_RUNNING:
  150. strTemp = "ZSKK_FPD_STATE_RUNNING";
  151. break;
  152. case CCOS_CALIBRATION_STATUS_PAUSE:
  153. strTemp = "ZSKK_FPD_STATE_PAUSE";
  154. break;
  155. case CCOS_CALIBRATION_STATUS_PREPARE:
  156. strTemp = "ZSKK_FPD_STATE_PREPARE";
  157. break;
  158. default:
  159. break;
  160. }
  161. m_CalibStatus = (CCOS_CALIBRATION_STATUS)nCalibrationStatus;
  162. m_EventCenter->OnNotify((int)ATTRACTION_SET, AttrKey::CalibrationStatus, in);
  163. Info("CalibrationStatus: {$}",strTemp.c_str());
  164. return RET_STATUS::RET_SUCCEED;
  165. }
  166. CCOS_CALIBRATION_STATUS OEM_IF nsFPD::CalibUnit::GetCalibrationStatus()
  167. {
  168. return m_CalibStatus;
  169. }
  170. RET_STATUS nsFPD::CalibUnit::JSGetCalibProgress(std::string & out)
  171. {
  172. out = m_strCalibProgress;
  173. return RET_STATUS::RET_SUCCEED;
  174. }
  175. RET_STATUS nsFPD::CalibUnit::SetCalibrationProgress(string in)
  176. {
  177. Info("SetCalibrationProgress in:{$}", in);
  178. if (in == "")
  179. {
  180. return RET_STATUS::RET_FAILED;
  181. }
  182. m_strCalibProgress = in;
  183. m_EventCenter->OnNotify((int)ATTRACTION_SET, AttrKey::CalibrationProgress, m_strCalibProgress);
  184. Info("CalibrationProgress: {$}", m_strCalibProgress);
  185. return RET_STATUS::RET_SUCCEED;
  186. }
  187. CCOS_CALIBRATION_TYPE OEM_IF nsFPD::CalibUnit::GetCalibrationType()
  188. {
  189. return m_CurrentCalibType;
  190. }
  191. RET_STATUS nsFPD::CalibUnit::JSUploadCalibrationFiles(std::string in, std::string & out)
  192. {
  193. ResDataObject json;
  194. json.decode(in.c_str());
  195. string mode = "";
  196. try
  197. {
  198. mode = (string)json[0];
  199. }
  200. catch (...)
  201. {
  202. return RET_STATUS::RET_FAILED;
  203. }
  204. return UploadCalibrationFiles(mode);
  205. }
  206. RET_STATUS nsFPD::CalibUnit::JSGetUploadCalibrationFilesResult(std::string & out)
  207. {
  208. out = m_strUploadCalibrationFilesResult;
  209. return RET_STATUS::RET_SUCCEED;
  210. }
  211. RET_STATUS nsFPD::CalibUnit::SetUploadCalibrationFilesResult(string in)
  212. {
  213. Info("SetUploadCalibrationFilesResult in:{$}", in);
  214. if (in == "")
  215. {
  216. return RET_STATUS::RET_FAILED;
  217. }
  218. m_strUploadCalibrationFilesResult = in;
  219. m_EventCenter->OnNotify((int)ATTRACTION_SET, AttrKey::UploadCalibrationFilesResult, m_strUploadCalibrationFilesResult);
  220. Info("UploadCalibrationFilesResult:{$}", m_strUploadCalibrationFilesResult);
  221. return RET_STATUS::RET_SUCCEED;
  222. }
  223. RET_STATUS nsFPD::CalibUnit::JSGetSupportCalibrationType(std::string& out)
  224. {
  225. ResDataObject tmp;
  226. if (Support_DarkCalib())
  227. {
  228. tmp.add("Offset", CCOS_CALIBRATION_TYPE_DARK);
  229. }
  230. if (Support_XrayCalib())
  231. {
  232. tmp.add("Gain", CCOS_CALIBRATION_TYPE_XRAY);
  233. }
  234. if (tmp.size() > 0)
  235. {
  236. out = tmp.encode();
  237. }
  238. else
  239. {
  240. out = "";
  241. return RET_STATUS::RET_NOSUPPORT;
  242. }
  243. return RET_STATUS::RET_SUCCEED;
  244. }
  245. bool nsFPD::CalibUnit::Support_DarkCalib()
  246. {
  247. return false;
  248. }
  249. bool nsFPD::CalibUnit::Support_XrayCalib()
  250. {
  251. return false;
  252. }
  253. RET_STATUS nsFPD::CalibUnit::JSGetHaveImgCalibration(std::string& out)
  254. {
  255. if (Support_HaveImageCalib())
  256. {
  257. out = "1";
  258. }
  259. else
  260. {
  261. out = "0";
  262. }
  263. Info("JSGetHaveImgCalibration out:{$}",out.c_str());
  264. return RET_STATUS::RET_SUCCEED;
  265. }
  266. bool nsFPD::CalibUnit::Support_HaveImageCalib()
  267. {
  268. return false;
  269. }
  270. RET_STATUS nsFPD::CalibUnit::JSGetCalibrationStep(std::string in, std::string& out)
  271. {
  272. Info("JSGetCalibrationStep. \n{$}", in.c_str());
  273. int nDetectorID = 0;
  274. string strCalibrationStepInfo;
  275. RET_STATUS nRet = GetCalibrationStep(nDetectorID, strCalibrationStepInfo);
  276. out = strCalibrationStepInfo;
  277. return nRet;
  278. }
  279. RET_STATUS nsFPD::CalibUnit::GetCalibrationStep(int nDetectorID, std::string& strCalibrationStepInfo)
  280. {
  281. return RET_STATUS::RET_SUCCEED;
  282. }
  283. RET_STATUS nsFPD::CalibUnit::JSAcceptCalibration(std::string in, std::string& out)
  284. {
  285. RET_STATUS nRet = AcceptCalibration();
  286. return nRet;
  287. }
  288. RET_STATUS nsFPD::CalibUnit::AcceptCalibration()
  289. {
  290. return RET_STATUS::RET_SUCCEED;
  291. }
  292. RET_STATUS nsFPD::CalibUnit::JSRejectCalibration(std::string in, std::string& out)
  293. {
  294. RET_STATUS nRet = RejectCalibration();
  295. return nRet;
  296. }
  297. RET_STATUS nsFPD::CalibUnit::RejectCalibration()
  298. {
  299. return RET_STATUS::RET_SUCCEED;
  300. }
  301. RET_STATUS nsFPD::CalibUnit::JSSaveCalibrationFile(std::string in, std::string& out)
  302. {
  303. Info("JSSaveCalibrationFile.\n{$}", in.c_str());
  304. ResDataObject jsonInput;
  305. jsonInput.decode(in.c_str());
  306. bool bSaveFlag = false;
  307. try
  308. {
  309. bSaveFlag = (bool)jsonInput[0];
  310. }
  311. catch (...)
  312. {
  313. Error("JSSaveCalibrationFile parameter error");
  314. return RET_STATUS::RET_FAILED;
  315. }
  316. RET_STATUS nRet = SaveCalibrationFile(bSaveFlag);
  317. return nRet;
  318. }
  319. RET_STATUS nsFPD::CalibUnit::SaveCalibrationFile(bool bSaveFlag)
  320. {
  321. return RET_STATUS::RET_SUCCEED;
  322. }
  323. RET_STATUS nsFPD::CalibUnit::JSGetSaveCalibrationFileFinish(std::string& out)
  324. {
  325. out = m_strSaveCalibrationFileFinish;
  326. return RET_STATUS::RET_SUCCEED;
  327. }
  328. RET_STATUS OEM_IF CCOS::Dev::Detail::Detector::CalibUnit::SetOffsetStatus(string in)
  329. {
  330. Info("SetOffsetStatus in: {$}", in);
  331. if (in == "")
  332. {
  333. return RET_STATUS::RET_FAILED;
  334. }
  335. m_strOffsetStatus = in;
  336. m_EventCenter->OnNotify((int)ATTRACTION_SET, AttrKey::OffsetStatus, in);
  337. return RET_STATUS::RET_SUCCEED;
  338. }
  339. RET_STATUS CCOS::Dev::Detail::Detector::CalibUnit::JSGetOffsetStatus(std::string& out)
  340. {
  341. Info("JSGetOffsetStatus");
  342. out = m_strOffsetStatus;
  343. return RET_STATUS::RET_SUCCEED;
  344. }
  345. RET_STATUS OEM_IF CCOS::Dev::Detail::Detector::CalibUnit::SetOffsetProgress(string in)
  346. {
  347. Info("SetOffsetProgress in: {$}", in);
  348. if (in == "")
  349. {
  350. return RET_STATUS::RET_FAILED;
  351. }
  352. m_strOffsetProgress = in;
  353. m_EventCenter->OnNotify((int)ATTRACTION_SET, AttrKey::OffsetProgress, in);
  354. return RET_STATUS::RET_SUCCEED;
  355. }
  356. RET_STATUS CCOS::Dev::Detail::Detector::CalibUnit::JSGetOffsetProgress(std::string& out)
  357. {
  358. Info("JSGetOffsetProgress");
  359. out = m_strOffsetProgress;
  360. return RET_STATUS::RET_SUCCEED;
  361. }
  362. RET_STATUS OEM_IF CCOS::Dev::Detail::Detector::CalibUnit::SetOffsetCounts(string in)
  363. {
  364. Info("SetOffsetCounts in: {$}", in);
  365. if (in == "")
  366. {
  367. return RET_STATUS::RET_FAILED;
  368. }
  369. m_strOffsetCounts = in;
  370. m_EventCenter->OnNotify((int)ATTRACTION_SET, AttrKey::OffsetCounts, in);
  371. return RET_STATUS::RET_SUCCEED;
  372. }
  373. RET_STATUS CCOS::Dev::Detail::Detector::CalibUnit::JSGetOffsetCounts(std::string& out)
  374. {
  375. Info("JSGetOffsetCounts");
  376. out = m_strOffsetCounts;
  377. return RET_STATUS::RET_SUCCEED;
  378. }
  379. RET_STATUS OEM_IF CCOS::Dev::Detail::Detector::CalibUnit::SetOffsetInterval(string in)
  380. {
  381. Info("SetOffsetInterval in: {$}", in);
  382. if (in == "")
  383. {
  384. return RET_STATUS::RET_FAILED;
  385. }
  386. m_strOffsetInterval = in;
  387. m_EventCenter->OnNotify((int)ATTRACTION_SET, AttrKey::OffsetInterval, in);
  388. return RET_STATUS::RET_SUCCEED;
  389. }
  390. RET_STATUS CCOS::Dev::Detail::Detector::CalibUnit::JSGetOffsetInterval(std::string& out)
  391. {
  392. Info("JSGetOffsetInterval");
  393. out = m_strOffsetInterval;
  394. return RET_STATUS::RET_SUCCEED;
  395. }
  396. void OEM_IF nsFPD::CalibUnit::SetSaveCalibrationFileFinish(bool bResult)
  397. {
  398. string strFPDInfo = std::to_string(bResult);
  399. m_strSaveCalibrationFileFinish = strFPDInfo;
  400. m_EventCenter->OnNotify((int)ATTRACTION_SET, AttrKey::SaveCalibrationFileFinish, m_strSaveCalibrationFileFinish);
  401. Info("SetSaveCalibrationFileFinish. {$}", strFPDInfo);
  402. }