DIOS.Dev.FPD.CalibUnit.cpp 11 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476
  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* //mLog::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. //mLog::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. //mLog::Info("JSActiveCalibration. {$}", in.c_str());
  41. //mLog::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. //mLog::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. //mLog::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. //mLog::Info("JSPrepareCalibration.");
  83. return PrepareCalibration();
  84. }
  85. RET_STATUS nsFPD::CalibUnit::JSStartCalibration(std::string in, std::string& out)
  86. {
  87. //mLog::Info("JSStartCalibration.");
  88. return StartCalibration();
  89. }
  90. RET_STATUS OEM_IF nsFPD::CalibUnit::PauseCalibration()
  91. {
  92. //mLog::Info("PauseCalibration.");
  93. return RET_STATUS::RET_SUCCEED;
  94. }
  95. RET_STATUS nsFPD::CalibUnit::JSStopCalibration(std::string in, std::string& out)
  96. {
  97. //mLog::Info("JSStopCalibration.");
  98. return StopCalibration();
  99. }
  100. RET_STATUS nsFPD::CalibUnit::JSSetCorrectionType(std::string in, std::string & out)
  101. {
  102. return RET_STATUS::RET_SUCCEED;
  103. }
  104. RET_STATUS nsFPD::CalibUnit::JSGetCalibStatus(std::string & out)
  105. {
  106. auto szFDinfo = std::to_string(m_CalibStatus);
  107. out = szFDinfo;
  108. return RET_STATUS::RET_SUCCEED;
  109. }
  110. RET_STATUS nsFPD::CalibUnit::SetCalibrationStatus(string in)
  111. {
  112. //mLog::Info("SetCalibrationStatus in:{$}", in);
  113. if (in == "")
  114. {
  115. return RET_STATUS::RET_FAILED;
  116. }
  117. int nCalibrationStatus = atoi(in.c_str());
  118. string strTemp = "";
  119. switch (nCalibrationStatus)
  120. {
  121. case CCOS_CALIBRATION_STATUS_ERROR:
  122. strTemp = "ZSKK_FPD_STATE_ERROR";
  123. break;
  124. case CCOS_CALIBRATION_STATUS_STANDBY:
  125. strTemp = "ZSKK_FPD_STATE_STANDBY";
  126. break;
  127. case CCOS_CALIBRATION_STATUS_ACTIVE:
  128. strTemp = "ZSKK_FPD_STATE_ACTIVE";
  129. break;
  130. case CCOS_CALIBRATION_STATUS_RUNNING:
  131. strTemp = "ZSKK_FPD_STATE_RUNNING";
  132. break;
  133. case CCOS_CALIBRATION_STATUS_PAUSE:
  134. strTemp = "ZSKK_FPD_STATE_PAUSE";
  135. break;
  136. case CCOS_CALIBRATION_STATUS_PREPARE:
  137. strTemp = "ZSKK_FPD_STATE_PREPARE";
  138. break;
  139. default:
  140. break;
  141. }
  142. m_CalibStatus = (CCOS_CALIBRATION_STATUS)nCalibrationStatus;
  143. m_EventCenter->OnNotify((int)ATTRACTION_SET, AttrKey::CalibrationStatus, in);
  144. //mLog::Info("CalibrationStatus: {$}",strTemp.c_str());
  145. return RET_STATUS::RET_SUCCEED;
  146. }
  147. CCOS_CALIBRATION_STATUS OEM_IF nsFPD::CalibUnit::GetCalibrationStatus()
  148. {
  149. return m_CalibStatus;
  150. }
  151. RET_STATUS nsFPD::CalibUnit::JSGetCalibProgress(std::string & out)
  152. {
  153. out = m_strCalibProgress;
  154. return RET_STATUS::RET_SUCCEED;
  155. }
  156. RET_STATUS nsFPD::CalibUnit::SetCalibrationProgress(string in)
  157. {
  158. //mLog::Info("SetCalibrationProgress in:{$}", in);
  159. if (in == "")
  160. {
  161. return RET_STATUS::RET_FAILED;
  162. }
  163. m_strCalibProgress = in;
  164. m_EventCenter->OnNotify((int)ATTRACTION_SET, AttrKey::CalibrationProgress, m_strCalibProgress);
  165. //mLog::Info("CalibrationProgress: {$}", m_strCalibProgress);
  166. return RET_STATUS::RET_SUCCEED;
  167. }
  168. CCOS_CALIBRATION_TYPE OEM_IF nsFPD::CalibUnit::GetCalibrationType()
  169. {
  170. return m_CurrentCalibType;
  171. }
  172. RET_STATUS nsFPD::CalibUnit::JSUploadCalibrationFiles(std::string in, std::string & out)
  173. {
  174. ResDataObject json;
  175. json.decode(in.c_str());
  176. string mode = "";
  177. try
  178. {
  179. mode = (string)json[0];
  180. }
  181. catch (...)
  182. {
  183. return RET_STATUS::RET_FAILED;
  184. }
  185. return UploadCalibrationFiles(mode);
  186. }
  187. RET_STATUS nsFPD::CalibUnit::JSGetUploadCalibrationFilesResult(std::string & out)
  188. {
  189. out = m_strUploadCalibrationFilesResult;
  190. return RET_STATUS::RET_SUCCEED;
  191. }
  192. RET_STATUS nsFPD::CalibUnit::SetUploadCalibrationFilesResult(string in)
  193. {
  194. //mLog::Info("SetUploadCalibrationFilesResult in:{$}", in);
  195. if (in == "")
  196. {
  197. return RET_STATUS::RET_FAILED;
  198. }
  199. m_strUploadCalibrationFilesResult = in;
  200. m_EventCenter->OnNotify((int)ATTRACTION_SET, AttrKey::UploadCalibrationFilesResult, m_strUploadCalibrationFilesResult);
  201. //mLog::Info("UploadCalibrationFilesResult:{$}", m_strUploadCalibrationFilesResult);
  202. return RET_STATUS::RET_SUCCEED;
  203. }
  204. RET_STATUS nsFPD::CalibUnit::JSGetSupportCalibrationType(std::string& out)
  205. {
  206. ResDataObject tmp;
  207. if (Support_DarkCalib())
  208. {
  209. tmp.add("Offset", CCOS_CALIBRATION_TYPE_DARK);
  210. }
  211. if (Support_XrayCalib())
  212. {
  213. tmp.add("Gain", CCOS_CALIBRATION_TYPE_XRAY);
  214. }
  215. if (tmp.size() > 0)
  216. {
  217. out = tmp.encode();
  218. }
  219. else
  220. {
  221. out = "";
  222. return RET_STATUS::RET_NOSUPPORT;
  223. }
  224. return RET_STATUS::RET_SUCCEED;
  225. }
  226. bool nsFPD::CalibUnit::Support_DarkCalib()
  227. {
  228. return false;
  229. }
  230. bool nsFPD::CalibUnit::Support_XrayCalib()
  231. {
  232. return false;
  233. }
  234. RET_STATUS nsFPD::CalibUnit::JSGetHaveImgCalibration(std::string& out)
  235. {
  236. if (Support_HaveImageCalib())
  237. {
  238. out = "1";
  239. }
  240. else
  241. {
  242. out = "0";
  243. }
  244. //mLog::Info("JSGetHaveImgCalibration out:{$}",out.c_str());
  245. return RET_STATUS::RET_SUCCEED;
  246. }
  247. bool nsFPD::CalibUnit::Support_HaveImageCalib()
  248. {
  249. return false;
  250. }
  251. RET_STATUS nsFPD::CalibUnit::JSGetCalibrationStep(std::string in, std::string& out)
  252. {
  253. //mLog::Info("JSGetCalibrationStep. \n{$}", in.c_str());
  254. int nDetectorID = 0;
  255. string strCalibrationStepInfo;
  256. RET_STATUS nRet = GetCalibrationStep(nDetectorID, strCalibrationStepInfo);
  257. out = strCalibrationStepInfo;
  258. return nRet;
  259. }
  260. RET_STATUS nsFPD::CalibUnit::GetCalibrationStep(int nDetectorID, std::string& strCalibrationStepInfo)
  261. {
  262. return RET_STATUS::RET_SUCCEED;
  263. }
  264. RET_STATUS nsFPD::CalibUnit::JSAcceptCalibration(std::string in, std::string& out)
  265. {
  266. RET_STATUS nRet = AcceptCalibration();
  267. return nRet;
  268. }
  269. RET_STATUS nsFPD::CalibUnit::AcceptCalibration()
  270. {
  271. return RET_STATUS::RET_SUCCEED;
  272. }
  273. RET_STATUS nsFPD::CalibUnit::JSRejectCalibration(std::string in, std::string& out)
  274. {
  275. RET_STATUS nRet = RejectCalibration();
  276. return nRet;
  277. }
  278. RET_STATUS nsFPD::CalibUnit::RejectCalibration()
  279. {
  280. return RET_STATUS::RET_SUCCEED;
  281. }
  282. RET_STATUS nsFPD::CalibUnit::JSSaveCalibrationFile(std::string in, std::string& out)
  283. {
  284. //mLog::Info("JSSaveCalibrationFile.\n{$}", in.c_str());
  285. ResDataObject jsonInput;
  286. jsonInput.decode(in.c_str());
  287. bool bSaveFlag = false;
  288. try
  289. {
  290. bSaveFlag = (bool)jsonInput[0];
  291. }
  292. catch (...)
  293. {
  294. //mLog::Error("JSSaveCalibrationFile parameter error");
  295. return RET_STATUS::RET_FAILED;
  296. }
  297. RET_STATUS nRet = SaveCalibrationFile(bSaveFlag);
  298. return nRet;
  299. }
  300. RET_STATUS nsFPD::CalibUnit::SaveCalibrationFile(bool bSaveFlag)
  301. {
  302. return RET_STATUS::RET_SUCCEED;
  303. }
  304. RET_STATUS nsFPD::CalibUnit::JSGetSaveCalibrationFileFinish(std::string& out)
  305. {
  306. out = m_strSaveCalibrationFileFinish;
  307. return RET_STATUS::RET_SUCCEED;
  308. }
  309. void OEM_IF nsFPD::CalibUnit::SetSaveCalibrationFileFinish(bool bResult)
  310. {
  311. string strFPDInfo = std::to_string(bResult);
  312. m_strSaveCalibrationFileFinish = strFPDInfo;
  313. m_EventCenter->OnNotify((int)ATTRACTION_SET, AttrKey::SaveCalibrationFileFinish, m_strSaveCalibrationFileFinish);
  314. //mLog::Info("SetSaveCalibrationFileFinish. {$}", strFPDInfo);
  315. }
  316. RET_STATUS nsFPD::CalibUnit::JSStartOffset(std::string in, std::string& out)
  317. {
  318. //mLog::Info("JSStartOffset: {$}", in.c_str());
  319. ResDataObject jsonInput;
  320. jsonInput.decode(in.c_str());
  321. bool isAll = false;
  322. try
  323. {
  324. isAll = (bool)jsonInput[0];
  325. }
  326. catch (...)
  327. {
  328. //mLog::Error("JSStartOffset parameter error");
  329. return RET_STATUS::RET_FAILED;
  330. }
  331. return StartOffset(isAll);
  332. }
  333. RET_STATUS nsFPD::CalibUnit::StartOffset(bool isAll)
  334. {
  335. return RET_STATUS::RET_SUCCEED;
  336. }
  337. RET_STATUS nsFPD::CalibUnit::JSAbortOffset(std::string in, std::string& out)
  338. {
  339. return AbortOffset();
  340. }
  341. RET_STATUS nsFPD::CalibUnit::AbortOffset()
  342. {
  343. return RET_STATUS::RET_SUCCEED;
  344. }
  345. RET_STATUS CCOS::Dev::Detail::Detector::CalibUnit::JSGetOffsetStatus(std::string& out)
  346. {
  347. out = m_strOffsetStatus;
  348. return RET_STATUS::RET_SUCCEED;
  349. }
  350. RET_STATUS CCOS::Dev::Detail::Detector::CalibUnit::SetOffsetStatus(std::string in)
  351. {
  352. m_strOffsetStatus = in;
  353. m_EventCenter->OnNotify((int)ATTRACTION_SET, "OffsetStatus", m_strOffsetStatus);
  354. return RET_STATUS::RET_SUCCEED;
  355. }
  356. RET_STATUS CCOS::Dev::Detail::Detector::CalibUnit::JSGetOffsetCounts(std::string& out)
  357. {
  358. out = m_strOffsetCounts;
  359. return RET_STATUS::RET_SUCCEED;
  360. }
  361. RET_STATUS CCOS::Dev::Detail::Detector::CalibUnit::SetOffsetCounts(std::string in)
  362. {
  363. m_strOffsetCounts = in;
  364. m_EventCenter->OnNotify((int)ATTRACTION_SET, "OffsetCounts", m_strOffsetCounts);
  365. return RET_STATUS::RET_SUCCEED;
  366. }
  367. RET_STATUS CCOS::Dev::Detail::Detector::CalibUnit::JSGetOffsetProgress(std::string& out)
  368. {
  369. out = m_strOffsetProgress;
  370. return RET_STATUS::RET_SUCCEED;
  371. }
  372. RET_STATUS CCOS::Dev::Detail::Detector::CalibUnit::SetOffsetProgress(std::string in)
  373. {
  374. m_strOffsetProgress = in;
  375. m_EventCenter->OnNotify((int)ATTRACTION_SET, "OffsetProgress", m_strOffsetProgress);
  376. return RET_STATUS::RET_SUCCEED;
  377. }
  378. RET_STATUS CCOS::Dev::Detail::Detector::CalibUnit::JSGetOffsetInterval(std::string& out)
  379. {
  380. out = m_strOffsetInterval;
  381. return RET_STATUS::RET_SUCCEED;
  382. }
  383. RET_STATUS CCOS::Dev::Detail::Detector::CalibUnit::SetOffsetInterval(std::string in)
  384. {
  385. m_strOffsetInterval = in;
  386. return RET_STATUS::RET_SUCCEED;
  387. }
  388. RET_STATUS CCOS::Dev::Detail::Detector::CalibUnit::JSUpdateOffsetInterval(std::string in, std::string& out)
  389. {
  390. m_strOffsetInterval = in;
  391. out = m_strOffsetInterval;
  392. return RET_STATUS::RET_SUCCEED;
  393. }