DIOS.Dev.FPD.AcqUnit.cpp 32 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394959697989910010110210310410510610710810911011111211311411511611711811912012112212312412512612712812913013113213313413513613713813914014114214314414514614714814915015115215315415515615715815916016116216316416516616716816917017117217317417517617717817918018118218318418518618718818919019119219319419519619719819920020120220320420520620720820921021121221321421521621721821922022122222322422522622722822923023123223323423523623723823924024124224324424524624724824925025125225325425525625725825926026126226326426526626726826927027127227327427527627727827928028128228328428528628728828929029129229329429529629729829930030130230330430530630730830931031131231331431531631731831932032132232332432532632732832933033133233333433533633733833934034134234334434534634734834935035135235335435535635735835936036136236336436536636736836937037137237337437537637737837938038138238338438538638738838939039139239339439539639739839940040140240340440540640740840941041141241341441541641741841942042142242342442542642742842943043143243343443543643743843944044144244344444544644744844945045145245345445545645745845946046146246346446546646746846947047147247347447547647747847948048148248348448548648748848949049149249349449549649749849950050150250350450550650750850951051151251351451551651751851952052152252352452552652752852953053153253353453553653753853954054154254354454554654754854955055155255355455555655755855956056156256356456556656756856957057157257357457557657757857958058158258358458558658758858959059159259359459559659759859960060160260360460560660760860961061161261361461561661761861962062162262362462562662762862963063163263363463563663763863964064164264364464564664764864965065165265365465565665765865966066166266366466566666766866967067167267367467567667767867968068168268368468568668768868969069169269369469569669769869970070170270370470570670770870971071171271371471571671771871972072172272372472572672772872973073173273373473573673773873974074174274374474574674774874975075175275375475575675775875976076176276376476576676776876977077177277377477577677777877978078178278378478578678778878979079179279379479579679779879980080180280380480580680780880981081181281381481581681781881982082182282382482582682782882983083183283383483583683783883984084184284384484584684784884985085185285385485585685785885986086186286386486586686786886987087187287387487587687787887988088188288388488588688788888989089189289389489589689789889990090190290390490590690790890991091191291391491591691791891992092192292392492592692792892993093193293393493593693793893994094194294394494594694794894995095195295395495595695795895996096196296396496596696796896997097197297397497597697797897998098198298398498598698798898999099199299399499599699799899910001001100210031004100510061007100810091010101110121013101410151016101710181019102010211022102310241025102610271028102910301031103210331034103510361037103810391040104110421043104410451046104710481049105010511052105310541055105610571058105910601061106210631064106510661067106810691070107110721073107410751076107710781079108010811082108310841085108610871088108910901091109210931094109510961097109810991100110111021103110411051106110711081109111011111112111311141115111611171118111911201121112211231124112511261127112811291130113111321133113411351136113711381139114011411142114311441145114611471148114911501151115211531154115511561157115811591160116111621163116411651166116711681169117011711172117311741175117611771178117911801181118211831184118511861187118811891190119111921193119411951196119711981199120012011202120312041205120612071208120912101211121212131214121512161217121812191220122112221223122412251226122712281229123012311232123312341235123612371238123912401241124212431244124512461247124812491250125112521253125412551256125712581259126012611262126312641265126612671268126912701271127212731274127512761277127812791280128112821283128412851286128712881289
  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. // AcqUnit
  11. //-----------------------------------------------------------------------------
  12. nsFPD::AcqUnit::AcqUnit():
  13. m_pFullImageQueue(NULL),
  14. m_pPrevImageData(NULL),
  15. m_strZskkFPDState("0"),
  16. m_strNoNeedWaitImage("0"),
  17. m_strAutonumousMapFinish("0"),
  18. m_strLastImage(""),
  19. m_nFullWidth(3000),
  20. m_nFullHeight(3000),
  21. m_nPrevWidth(1500),
  22. m_nPrevHeight(1500),
  23. m_nBits(16)
  24. {
  25. }
  26. nsFPD::AcqUnit:: ~AcqUnit()
  27. {
  28. }
  29. void OEM_IF nsFPD::AcqUnit::SetEventCenter(std::shared_ptr <CCOS::Dev::IOEventCenter> EventCenter)
  30. {
  31. m_EventCenter = EventCenter;
  32. }
  33. RET_STATUS nsFPD::AcqUnit::JSSetAcqMode(std::string in, std::string & out)
  34. {
  35. ResDataObject json;
  36. json.decode(in.c_str());
  37. int mode = 0;
  38. Info ("JSSetAcqMode {$}", in.c_str ());
  39. if (json.GetFirstOf("P0") >= 0)
  40. {
  41. string strMode = json["P0"];
  42. if (strMode == "RAD")
  43. {
  44. mode = 1;
  45. }
  46. else if (strMode == "FLU")
  47. {
  48. mode = 3;
  49. }
  50. else
  51. mode = atoi(strMode.c_str());
  52. Info("StartAcquisition logicMode:{$}", mode);
  53. }
  54. SetAcqMode(mode);
  55. out = "test@SetAcqMode";
  56. return RET_STATUS::RET_SUCCEED;
  57. }
  58. RET_STATUS nsFPD::AcqUnit::JSSetGainMode(std::string in, std::string & out)
  59. {
  60. Info ("SetGainMode. {$}", in.c_str ());
  61. ResDataObject json;
  62. json.decode(in.c_str());
  63. string strP0 = (const char*)json["P0"];
  64. float fGain = stof(strP0.c_str());
  65. RET_STATUS ret = SetGainMode(fGain);
  66. out = "test@SetGainMode";
  67. return ret;
  68. }
  69. RET_STATUS nsFPD::AcqUnit::JSSetBinningMode(std::string in, std::string& out)
  70. {
  71. Info ("SetBinningMode. {$}", in.c_str ());
  72. ResDataObject json;
  73. json.decode(in.c_str());
  74. string strP0 = (const char*)json["P0"];
  75. string strP1 = (const char*)json["P1"];
  76. int nX = atoi(strP0.c_str());
  77. int nY = atoi(strP1.c_str());
  78. RET_STATUS ret = SetBinningMode(nX, nY);
  79. out = "test@SetBinningMode";
  80. return ret;
  81. }
  82. RET_STATUS nsFPD::AcqUnit::JSSetZoomMode(std::string in, std::string& out)
  83. {
  84. Info("SetZoomMode. {$}", in.c_str());
  85. ResDataObject json;
  86. json.decode(in.c_str());
  87. string strP0 = (const char*)json["P0"];
  88. string strP1 = (const char*)json["P1"];
  89. string strP2 = (const char*)json["P2"];
  90. string strP3 = (const char*)json["P3"];
  91. int nX1 = atoi(strP0.c_str());
  92. int nY1 = atoi(strP1.c_str());
  93. int nX2 = atoi(strP2.c_str());
  94. int nY2 = atoi(strP3.c_str());
  95. RET_STATUS ret = SetZoomMode(nX1, nY1, nX2, nY2);
  96. out = "test@SetZoomMode";
  97. return RET_STATUS::RET_SUCCEED;
  98. }
  99. RET_STATUS nsFPD::AcqUnit::JSSetDemoImage(std::string in, std::string& out)
  100. {
  101. ResDataObject json;
  102. json.decode(in.c_str());
  103. string strP0 = (const char*)json["P0"];
  104. Info("SetDemoImage. {$}", in.c_str());
  105. out = "test@SetDemoImage";
  106. SetDemoImage(strP0);
  107. return RET_STATUS::RET_SUCCEED;
  108. }
  109. RET_STATUS nsFPD::AcqUnit::SetDemoImage(string strFile)
  110. {
  111. Info("AcqUnit::SetDemoImage\n");
  112. return RET_STATUS::RET_SUCCEED;
  113. }
  114. bool OEM_IF nsFPD::AcqUnit::SetMaxBlockSize(const char *pQueName, DWORD BlockSize, DWORD FulBlockCount, DWORD PrevBlockCount)
  115. {
  116. return true;
  117. }
  118. bool OEM_IF nsFPD::AcqUnit::SetFulImageInfo(DWORD Height, DWORD Width, DWORD Bits, bool FetchFlag)
  119. {
  120. m_nFullWidth = Width;
  121. m_nFullHeight = Height;
  122. m_nBits = Bits;
  123. return true;
  124. }
  125. bool OEM_IF nsFPD::AcqUnit::SetPrevImageInfo(bool Support, DWORD Height, DWORD Width, bool FetchFlag)
  126. {
  127. m_nPrevWidth = Width;
  128. m_nPrevHeight = Height;
  129. return true;
  130. }
  131. RET_STATUS nsFPD::AcqUnit::JSGetZskkFPDState(std::string & out)
  132. {
  133. out = m_strZskkFPDState;
  134. return RET_STATUS::RET_SUCCEED;
  135. }
  136. bool OEM_IF nsFPD::AcqUnit::SetZskkFPDState(ZSKK_FPD_STATE state)
  137. {
  138. auto szFDinfo = std::to_string(state);
  139. m_strZskkFPDState = szFDinfo;
  140. m_EventCenter->OnNotify((int)ATTRACTION_SET, CcosZskkFPDState, m_strZskkFPDState);
  141. return true;
  142. }
  143. RET_STATUS nsFPD::AcqUnit::JSGetNoNeedWaitImage(std::string & out)
  144. {
  145. out = m_strNoNeedWaitImage;
  146. return RET_STATUS::RET_SUCCEED;
  147. }
  148. void OEM_NOTIFY nsFPD::AcqUnit::SendNoNeedWaitImage(bool bflag)
  149. {
  150. auto szFDinfo = std::to_string(bflag);
  151. m_EventCenter->OnNotify((int)ATTRACTION_SET, "NoNeedWaitImage", szFDinfo);
  152. Info("Send NoNeedWaitImage");
  153. return;
  154. }
  155. RET_STATUS nsFPD::AcqUnit::JSGetLastImage(std::string & out)
  156. {
  157. out = m_strLastImage;
  158. return RET_STATUS::RET_SUCCEED;
  159. }
  160. RET_STATUS OEM_IF nsFPD::AcqUnit::AddFrameWithRawHead(IMAGE_VIEW_TYPE eType, string ImageHead, unsigned char* pFrameBuff, DWORD FrameSize)
  161. {
  162. ResDataObject json;
  163. if (IMAGE_FULL == eType)
  164. {
  165. json.add("ImageType", 0);//IMAGE_TYPE_2D: 0; IMAGE_TYPE_3D: 1
  166. json.add("Viewtype", (int)eType);
  167. json.add("Sharememid", "0");
  168. json.add("Imageid", "0");
  169. json.add("Width", m_nFullWidth);
  170. json.add("Height", m_nFullHeight);
  171. json.add("Bit", m_nBits);
  172. }
  173. if (IMAGE_PREVIEW == eType || IMAGE_AEC_PREVIEW == eType)
  174. {
  175. json.add("ImageType", 0);//IMAGE_TYPE_2D: 0; IMAGE_TYPE_3D: 1
  176. json.add("Viewtype", (int)eType);
  177. json.add("Sharememid", "0");
  178. json.add("Imageid", "0");
  179. json.add("Width", m_nPrevWidth);
  180. json.add("Height", m_nPrevHeight);
  181. json.add("Bit", m_nBits);
  182. }
  183. m_strLastImage = json.encode();
  184. m_EventCenter->OnDataNotify((int)eType, "ImgDataInfo", m_strLastImage, ImageHead, (char *)pFrameBuff, FrameSize);
  185. Info("AddFrameWithRawHead:{$}", m_strLastImage.c_str());
  186. return RET_STATUS::RET_SUCCEED;
  187. }
  188. DWORD nsFPD::AcqUnit::AddFrame(IMAGE_VIEW_TYPE Type, string ImageHead, WORD* pFrameBuff, DWORD FrameSize)
  189. {
  190. return 0;
  191. }
  192. /********************************************************************/
  193. //
  194. //图像沿X轴做翻转,
  195. //pData:[IN][OUT] 图像数据
  196. //nWidth[IN] nHeight[IN]
  197. /********************************************************************/
  198. bool nsFPD::AcqUnit::FlipX(WORD* pData, UINT nWidth, UINT nHeight)
  199. {
  200. UINT j = 0;
  201. UINT i = 0;
  202. WORD temp;
  203. //修改翻转的判断,之前的代码会导致中央区域多翻转一个像素
  204. for (i = 0; i < nWidth; i++)
  205. {
  206. for (j = 0; j < nHeight / 2; j++)
  207. {
  208. int nSrc = j * nWidth + i;
  209. int nDes = (nHeight - j - 1) * nWidth + i;
  210. temp = pData[nSrc];
  211. pData[nSrc] = pData[nDes];
  212. pData[nDes] = temp;
  213. }
  214. }
  215. return true;
  216. }
  217. /********************************************************************/
  218. //
  219. //图像沿Y轴做翻转,
  220. //pData:[IN][OUT] 图像数据
  221. //nWidth[IN] nHeight[IN]
  222. /********************************************************************/
  223. bool nsFPD::AcqUnit::FlipY(WORD* pData, UINT nWidth, UINT nHeight)
  224. {
  225. UINT j = 0;
  226. UINT i = 0;
  227. WORD temp;
  228. //修改翻转的判断,之前的代码会导致中央区域多翻转一个像素
  229. for (i = 0; i < nHeight; i++)
  230. {
  231. for (j = 0; j < nWidth / 2; j++)
  232. {
  233. temp = pData[i * nWidth + j];
  234. pData[i * nWidth + j] = pData[(i + 1) * nWidth - j - 1];
  235. pData[(i + 1) * nWidth - j - 1] = temp;
  236. }
  237. }
  238. return true;
  239. }
  240. /***
  241. ** 说明:旋转图像
  242. ** 参数:nAngle,顺时针旋转角度,0 90 180 270
  243. ** addbyys20200810
  244. ***/
  245. bool nsFPD::AcqUnit::RotateImage(WORD* imageBuffer, int nImageHeight, int nImageWidth, int nAngle)
  246. {
  247. bool ret = true;
  248. if (NULL == imageBuffer || 0 == nImageHeight || 0 == nImageWidth)
  249. {
  250. return false;
  251. }
  252. int nTemp = 0;
  253. int i = 0, j = 0;//for loop
  254. WORD* ptempData;
  255. ptempData = new WORD[nImageHeight * nImageWidth];
  256. switch (nAngle)
  257. {
  258. case 90: //顺时针旋转90°
  259. //TPRINTA_INFO("Rotate 90 degrees clockwise");
  260. nTemp = nImageHeight;
  261. nImageHeight = nImageWidth;
  262. nImageWidth = nTemp;
  263. try
  264. {
  265. memcpy(ptempData, imageBuffer, nImageHeight * nImageWidth * sizeof(WORD));
  266. for (i = 0; i < nImageHeight; i++)
  267. {
  268. for (j = 0; j < nImageWidth; j++)
  269. {
  270. imageBuffer[i * nImageWidth + j] = ptempData[(nImageWidth - 1 - j) * nImageHeight + i];
  271. }
  272. }
  273. }
  274. catch (...)
  275. {
  276. //TPRINTA_INFO("Rotate image crashed");
  277. ret = false;
  278. }
  279. break;
  280. case 180: //顺时针旋转180°
  281. //TPRINTA_INFO("Rotate 180 degrees clockwise");
  282. try
  283. {
  284. memcpy(ptempData, imageBuffer, nImageHeight * nImageWidth * sizeof(WORD));
  285. for (i = 0; i < nImageWidth * nImageHeight; i++)
  286. {
  287. imageBuffer[i] = ptempData[nImageWidth * nImageHeight - 1 - i];
  288. }
  289. }
  290. catch (...)
  291. {
  292. //TPRINTA_INFO("Rotate image crashed");
  293. ret = false;
  294. }
  295. break;
  296. case 270: //顺时针旋转270°
  297. //TPRINTA_INFO("Rotate 270 degrees clockwise");
  298. nTemp = nImageHeight;
  299. nImageHeight = nImageWidth;
  300. nImageWidth = nTemp;
  301. try
  302. {
  303. memcpy(ptempData, imageBuffer, nImageWidth * nImageHeight * sizeof(WORD));
  304. for (i = 0; i < nImageHeight; i++)
  305. {
  306. for (j = 0; j < nImageWidth; j++)
  307. {
  308. imageBuffer[i * nImageWidth + j] = ptempData[j * nImageHeight + (nImageHeight - 1 - i)];
  309. }
  310. }
  311. }
  312. catch (...)
  313. {
  314. //TPRINTA_INFO("Rotate image crashed");
  315. ret = false;
  316. }
  317. break;
  318. default:
  319. ret = false;
  320. break;
  321. }
  322. delete[] ptempData;
  323. ptempData = NULL;
  324. return ret;
  325. }
  326. RET_STATUS nsFPD::AcqUnit::SetGainMode(float nGain)
  327. {
  328. return RET_STATUS::RET_SUCCEED;
  329. }
  330. RET_STATUS nsFPD::AcqUnit::SetBinningMode(int nBinningX, int nBinningY)
  331. {
  332. return RET_STATUS::RET_SUCCEED;
  333. }
  334. RET_STATUS nsFPD::AcqUnit::SetZoomMode(int nZOOMX1, int nZOOMY1, int nZOOMX2, int nZOOMY2)
  335. {
  336. return RET_STATUS::RET_SUCCEED;
  337. }
  338. RET_STATUS nsFPD::AcqUnit::JSAutonumousMapFinish(std::string& out)
  339. {
  340. out = m_strAutonumousMapFinish;
  341. return RET_STATUS::RET_SUCCEED;
  342. }
  343. void OEM_NOTIFY nsFPD::AcqUnit::SendAutonumousMapFinish(int nFlag)
  344. {
  345. string szFPDinfo = "";
  346. szFPDinfo = to_string(nFlag);
  347. m_strAutonumousMapFinish = szFPDinfo;
  348. m_EventCenter->OnNotify((int)ATTRACTION_SET, "AutonumousMapFinish", szFPDinfo);
  349. Info("Send AutonumousMapFinish({$})", szFPDinfo);
  350. return;
  351. }
  352. //超声相关
  353. RET_STATUS nsFPD::AcqUnit::JSSetFreeze(std::string in, std::string& out)
  354. {
  355. ResDataObject json;
  356. json.decode(in.c_str());
  357. int nFreeze = 0;//1 冻结 0 解冻
  358. Info("JSSetFreeze {$}", in.c_str());
  359. if (json.GetFirstOf("P0") >= 0)
  360. {
  361. string strFreeze = json["P0"];
  362. nFreeze = atoi(strFreeze.c_str());
  363. }
  364. out = "test@JSSetFreeze";
  365. return SetFreeze(nFreeze);
  366. }
  367. RET_STATUS nsFPD::AcqUnit::JSSwitchProbe(std::string in, std::string& out)
  368. {
  369. ResDataObject json;
  370. json.decode(in.c_str());
  371. int nProbeType = 1;//1 线阵 2 凸阵
  372. Info("JSSwitchProbe {$}", in.c_str());
  373. RET_STATUS ret = RET_STATUS::RET_FAILED;
  374. if (json.GetFirstOf("P0") >= 0)
  375. {
  376. string strProbeType = json["P0"];
  377. nProbeType = atoi(strProbeType.c_str());
  378. out = "test@JSSwitchProbe";
  379. ret = SwitchProbe(nProbeType);
  380. if (ret != RET_STATUS::RET_SUCCEED)
  381. {
  382. return ret;
  383. }
  384. m_EventCenter->OnNotify((int)ATTRACTION_SET, AttrKey::ProbeType, strProbeType);
  385. }
  386. return ret;
  387. }
  388. RET_STATUS nsFPD::AcqUnit::JSSwitchProbeMode(std::string in, std::string& out)
  389. {
  390. ResDataObject json;
  391. json.decode(in.c_str());
  392. int nProbeMode = 1;//1 B 2 C
  393. Info("JSSwitchProbeMode {$}", in.c_str());
  394. RET_STATUS ret = RET_STATUS::RET_FAILED;
  395. if (json.GetFirstOf("P0") >= 0)
  396. {
  397. string strProbeMode = json["P0"];
  398. nProbeMode = atoi(strProbeMode.c_str());
  399. out = "test@JSSwitchProbeMode";
  400. ret = SwitchProbeMode(nProbeMode);
  401. if (ret != RET_STATUS::RET_SUCCEED)
  402. {
  403. return ret;
  404. }
  405. m_EventCenter->OnNotify((int)ATTRACTION_SET, AttrKey::ProbeMode, strProbeMode);
  406. }
  407. return ret;
  408. }
  409. RET_STATUS nsFPD::AcqUnit::JSSetBGain(std::string in, std::string& out)
  410. {
  411. ResDataObject json;
  412. json.decode(in.c_str());
  413. int nGain = 50;
  414. Info("JSSetBGain {$}", in.c_str());
  415. RET_STATUS ret = RET_STATUS::RET_FAILED;
  416. if (json.GetFirstOf("P0") >= 0)
  417. {
  418. string strGain = json["P0"];
  419. nGain = atoi(strGain.c_str());
  420. out = "test@JSSetBGain";
  421. ret = SetBGain(nGain);
  422. if (ret != RET_STATUS::RET_SUCCEED)
  423. {
  424. return ret;
  425. }
  426. m_EventCenter->OnNotify((int)ATTRACTION_SET, AttrKey::BGain, strGain);
  427. }
  428. return ret;
  429. }
  430. RET_STATUS nsFPD::AcqUnit::JSSetBDepth(std::string in, std::string& out)
  431. {
  432. ResDataObject json;
  433. json.decode(in.c_str());
  434. int nDepth = 15; //范围 1-31
  435. Info("JSSetBDepth {$}", in.c_str());
  436. RET_STATUS ret = RET_STATUS::RET_FAILED;
  437. if (json.GetFirstOf("P0") >= 0)
  438. {
  439. string strDepth = json["P0"];
  440. nDepth = atoi(strDepth.c_str());
  441. out = "test@JSSetBDepth";
  442. ret = SetBDepth(nDepth);
  443. if (ret != RET_STATUS::RET_SUCCEED)
  444. {
  445. return ret;
  446. }
  447. m_EventCenter->OnNotify((int)ATTRACTION_SET, AttrKey::BDepth, strDepth);
  448. }
  449. return ret;
  450. }
  451. RET_STATUS nsFPD::AcqUnit::JSSetBFrequency(std::string in, std::string& out)
  452. {
  453. ResDataObject json;
  454. json.decode(in.c_str());
  455. //线阵 5.00 6.67 7.50 8.00 10.00 单位(Hz)
  456. //凸阵 2.90 3.50 5.00 单位(Hz)
  457. float frequency = 5.00f;
  458. Info("JSSetBFrequency {$}", in.c_str());
  459. RET_STATUS ret = RET_STATUS::RET_FAILED;
  460. if (json.GetFirstOf("P0") >= 0)
  461. {
  462. string strFrequency = json["P0"];
  463. frequency = stof(strFrequency);
  464. out = "test@JSSetBFrequency";
  465. ret = SetBFrequency(frequency);
  466. if (ret != RET_STATUS::RET_SUCCEED)
  467. {
  468. return ret;
  469. }
  470. m_EventCenter->OnNotify((int)ATTRACTION_SET, AttrKey::BFrequency, strFrequency);
  471. }
  472. return ret;
  473. }
  474. RET_STATUS nsFPD::AcqUnit::JSSetBFocus(std::string in, std::string& out)
  475. {
  476. ResDataObject json;
  477. json.decode(in.c_str());
  478. int nFocus = 7; //范围 0-15
  479. Info("JSSetBFocus {$}", in.c_str());
  480. RET_STATUS ret = RET_STATUS::RET_FAILED;
  481. if (json.GetFirstOf("P0") >= 0)
  482. {
  483. string strFocus = json["P0"];
  484. nFocus = atoi(strFocus.c_str());
  485. out = "test@JSSetBFocus";
  486. ret = SetBFocus(nFocus);
  487. if (ret != RET_STATUS::RET_SUCCEED)
  488. {
  489. return ret;
  490. }
  491. m_EventCenter->OnNotify((int)ATTRACTION_SET, AttrKey::BFocus, strFocus);
  492. }
  493. return ret;
  494. }
  495. RET_STATUS nsFPD::AcqUnit::JSSetBHarmonic(std::string in, std::string& out)
  496. {
  497. ResDataObject json;
  498. json.decode(in.c_str());
  499. int nHarmonic = 0; //0 关 1 开
  500. Info("JSSetBHarmonic {$}", in.c_str());
  501. RET_STATUS ret = RET_STATUS::RET_FAILED;
  502. if (json.GetFirstOf("P0") >= 0)
  503. {
  504. string strHarmonic = json["P0"];
  505. nHarmonic = atoi(strHarmonic.c_str());
  506. out = "test@JSSetBHarmonic";
  507. ret = SetBHarmonic(nHarmonic);
  508. if (ret != RET_STATUS::RET_SUCCEED)
  509. {
  510. return ret;
  511. }
  512. m_EventCenter->OnNotify((int)ATTRACTION_SET, AttrKey::BHarmonic, strHarmonic);
  513. }
  514. return ret;
  515. }
  516. RET_STATUS nsFPD::AcqUnit::JSSetBPower(std::string in, std::string& out)
  517. {
  518. ResDataObject json;
  519. json.decode(in.c_str());
  520. int nPower = 0; //0-3
  521. Info("JSSetBPower {$}", in.c_str());
  522. RET_STATUS ret = RET_STATUS::RET_FAILED;
  523. if (json.GetFirstOf("P0") >= 0)
  524. {
  525. string strPower = json["P0"];
  526. nPower = atoi(strPower.c_str());
  527. out = "test@JSSetBPower";
  528. ret = SetBPower(nPower);
  529. if (ret != RET_STATUS::RET_SUCCEED)
  530. {
  531. return ret;
  532. }
  533. m_EventCenter->OnNotify((int)ATTRACTION_SET, AttrKey::BPower, strPower);
  534. }
  535. return ret;
  536. }
  537. RET_STATUS nsFPD::AcqUnit::JSSetBDynamicRange(std::string in, std::string& out)
  538. {
  539. ResDataObject json;
  540. json.decode(in.c_str());
  541. int nRange = 0; //0-15
  542. Info("JSSetBDynamicRange {$}", in.c_str());
  543. RET_STATUS ret = RET_STATUS::RET_FAILED;
  544. if (json.GetFirstOf("P0") >= 0)
  545. {
  546. string strRange = json["P0"];
  547. nRange = atoi(strRange.c_str());
  548. out = "test@JSSetBDynamicRange";
  549. ret = SetBDynamicRange(nRange);
  550. if (ret != RET_STATUS::RET_SUCCEED)
  551. {
  552. return ret;
  553. }
  554. m_EventCenter->OnNotify((int)ATTRACTION_SET, AttrKey::BDynamicRange, strRange);
  555. }
  556. return ret;
  557. }
  558. RET_STATUS nsFPD::AcqUnit::JSGetBDepth(std::string in, std::string& out)
  559. {
  560. Info("JSGetBDepth");
  561. int nDepth = 0;
  562. float fCm = 0.0f;
  563. RET_STATUS ret = GetBDepth(nDepth, fCm);
  564. if (ret != RET_STATUS::RET_SUCCEED)
  565. {
  566. return ret;
  567. }
  568. ResDataObject json;
  569. std::string strDepth = std::to_string(nDepth);
  570. std::string strDepthCm = std::to_string(fCm);
  571. json.add(AttrKey::BDepth, strDepth.c_str());
  572. json.add(AttrKey::BDepthCm, strDepthCm.c_str());
  573. string result = json.encode();
  574. out = result;
  575. return ret;
  576. }
  577. RET_STATUS nsFPD::AcqUnit::JSGetBFrequency(std::string in, std::string& out)
  578. {
  579. Info("JSGetBFrequency");
  580. float frequency = 0.0f;
  581. RET_STATUS ret = GetBFrequency(frequency);
  582. if (ret != RET_STATUS::RET_SUCCEED)
  583. {
  584. return ret;
  585. }
  586. ResDataObject json;
  587. std::string strFrequency = std::to_string(frequency);
  588. json.add(AttrKey::BFrequency, strFrequency.c_str());
  589. string result = json.encode();
  590. out = result;
  591. return ret;
  592. }
  593. RET_STATUS nsFPD::AcqUnit::JSGetBGain(std::string in, std::string& out)
  594. {
  595. Info("JSGetBGain");
  596. int nGain = 0;
  597. RET_STATUS ret = GetBGain(nGain);
  598. if (ret != RET_STATUS::RET_SUCCEED)
  599. {
  600. return ret;
  601. }
  602. ResDataObject json;
  603. std::string strGain = std::to_string(nGain);
  604. json.add(AttrKey::BGain, strGain.c_str());
  605. string result = json.encode();
  606. out = result;
  607. return ret;
  608. }
  609. RET_STATUS nsFPD::AcqUnit::JSGetBFocus(std::string in, std::string& out)
  610. {
  611. Info("JSGetBFocus");
  612. int nFocus = 0;
  613. float fCm = 0.0f;
  614. RET_STATUS ret = GetBFocus(nFocus,fCm);
  615. if (ret != RET_STATUS::RET_SUCCEED)
  616. {
  617. return ret;
  618. }
  619. ResDataObject json;
  620. std::string strFocus = std::to_string(nFocus);
  621. std::string strFocusCm = std::to_string(fCm);
  622. json.add(AttrKey::BFocus, strFocus.c_str());
  623. json.add(AttrKey::BFocusCm, strFocusCm.c_str());
  624. string result = json.encode();
  625. out = result;
  626. return ret;
  627. }
  628. RET_STATUS nsFPD::AcqUnit::JSGetBDynamicRange(std::string in, std::string& out)
  629. {
  630. Info("JSGetBDynamicRange");
  631. int nRange = 0;
  632. RET_STATUS ret = GetBDynamicRange(nRange);
  633. if (ret != RET_STATUS::RET_SUCCEED)
  634. {
  635. return ret;
  636. }
  637. ResDataObject json;
  638. std::string strRange = std::to_string(nRange);
  639. json.add(AttrKey::BDynamicRange, strRange.c_str());
  640. string result = json.encode();
  641. out = result;
  642. return ret;
  643. }
  644. RET_STATUS nsFPD::AcqUnit::JSSetCRoi(std::string in, std::string& out)
  645. {
  646. ResDataObject json;
  647. json.decode(in.c_str());
  648. int x1 = 0, x2 = 0, y1 = 0, y2 = 0; //x 1-640 y 1-480
  649. Info("JSSetCRoi {$}", in.c_str());
  650. RET_STATUS ret = RET_STATUS::RET_FAILED;
  651. string strNotifyX1;
  652. string strNotifyX2;
  653. string strNotifyy1;
  654. string strNotifyy2;
  655. if (json.GetFirstOf("P0") >= 0)
  656. {
  657. string strx1 = json["P0"];
  658. x1 = atoi(strx1.c_str());
  659. strNotifyX1 = strx1;
  660. }
  661. if (json.GetFirstOf("P1") >= 0)
  662. {
  663. string strx2 = json["P1"];
  664. x2 = atoi(strx2.c_str());
  665. strNotifyX2 = strx2;
  666. }
  667. if (json.GetFirstOf("P2") >= 0)
  668. {
  669. string stry1 = json["P2"];
  670. y1 = atoi(stry1.c_str());
  671. strNotifyy1 = stry1;
  672. }
  673. if (json.GetFirstOf("P3") >= 0)
  674. {
  675. string stry2 = json["P3"];
  676. y2 = atoi(stry2.c_str());
  677. strNotifyy2 = stry2;
  678. }
  679. ret = SetCRoi(x1, x2, y1, y2);
  680. if (ret != RET_STATUS::RET_SUCCEED)
  681. {
  682. return ret;
  683. }
  684. out = "test@JSSetCRoi";
  685. m_EventCenter->OnNotify((int)ATTRACTION_SET, AttrKey::CxLeft, strNotifyX1);
  686. m_EventCenter->OnNotify((int)ATTRACTION_SET, AttrKey::CxRight, strNotifyX2);
  687. m_EventCenter->OnNotify((int)ATTRACTION_SET, AttrKey::CyTop, strNotifyy1);
  688. m_EventCenter->OnNotify((int)ATTRACTION_SET, AttrKey::CyBottom, strNotifyy2);
  689. return ret;
  690. }
  691. RET_STATUS nsFPD::AcqUnit::JSSetCGain(std::string in, std::string& out)
  692. {
  693. ResDataObject json;
  694. json.decode(in.c_str());
  695. int nGain = 0; //0-255
  696. Info("JSSetCGain {$}", in.c_str());
  697. RET_STATUS ret = RET_STATUS::RET_FAILED;
  698. if (json.GetFirstOf("P0") >= 0)
  699. {
  700. string strGain = json["P0"];
  701. nGain = atoi(strGain.c_str());
  702. out = "test@JSSetCGain";
  703. ret = SetCGain(nGain);
  704. if (ret != RET_STATUS::RET_SUCCEED)
  705. {
  706. return ret;
  707. }
  708. m_EventCenter->OnNotify((int)ATTRACTION_SET, AttrKey::CGain, strGain);
  709. }
  710. return ret;
  711. }
  712. RET_STATUS nsFPD::AcqUnit::JSSetPostLevel(std::string in, std::string& out)
  713. {
  714. ResDataObject json;
  715. json.decode(in.c_str());
  716. int nLevel = 3; //0-5
  717. Info("JSSetPostLevel {$}", in.c_str());
  718. RET_STATUS ret = RET_STATUS::RET_FAILED;
  719. if (json.GetFirstOf("P0") >= 0)
  720. {
  721. string strLevel = json["P0"];
  722. nLevel = atoi(strLevel.c_str());
  723. out = "test@JSSetPostLevel";
  724. ret = SetPostLevel(nLevel);
  725. if (ret != RET_STATUS::RET_SUCCEED)
  726. {
  727. return ret;
  728. }
  729. m_EventCenter->OnNotify((int)ATTRACTION_SET, AttrKey::PostLevel, strLevel);
  730. }
  731. return ret;
  732. }
  733. RET_STATUS nsFPD::AcqUnit::JSSetMirror(std::string in, std::string& out)
  734. {
  735. ResDataObject json;
  736. json.decode(in.c_str());
  737. int nMirror = 0; //1 镜像 0 取消镜像
  738. Info("JSSetMirror {$}", in.c_str());
  739. RET_STATUS ret = RET_STATUS::RET_FAILED;
  740. if (json.GetFirstOf("P0") >= 0)
  741. {
  742. string strMirror = json["P0"];
  743. nMirror = atoi(strMirror.c_str());
  744. out = "test@JSSetMirror";
  745. ret = SetMirror(nMirror);
  746. if (ret != RET_STATUS::RET_SUCCEED)
  747. {
  748. return ret;
  749. }
  750. m_EventCenter->OnNotify((int)ATTRACTION_SET, AttrKey::Mirror, strMirror);
  751. }
  752. return ret;
  753. }
  754. RET_STATUS nsFPD::AcqUnit::JSSetCFrequency(std::string in, std::string& out)
  755. {
  756. ResDataObject json;
  757. json.decode(in.c_str());
  758. float frequency = 0.0f;
  759. Info("JSSetCFrequency {$}", in.c_str());
  760. RET_STATUS ret = RET_STATUS::RET_FAILED;
  761. if (json.GetFirstOf("P0") >= 0)
  762. {
  763. string strFrequency = json["P0"];
  764. frequency = stof(strFrequency);
  765. out = "test@JSSetCFrequency";
  766. ret = SetCFrequency(frequency);
  767. if (ret != RET_STATUS::RET_SUCCEED)
  768. {
  769. return ret;
  770. }
  771. m_EventCenter->OnNotify((int)ATTRACTION_SET, AttrKey::CFrequency, strFrequency);
  772. }
  773. return ret;
  774. }
  775. RET_STATUS nsFPD::AcqUnit::JSSetCSpeedWallFilter(std::string in, std::string& out)
  776. {
  777. ResDataObject json;
  778. json.decode(in.c_str());
  779. int nSpeedWallFilter = 0; //0-31
  780. Info("JSSetCSpeedWallFilter {$}", in.c_str());
  781. RET_STATUS ret = RET_STATUS::RET_FAILED;
  782. if (json.GetFirstOf("P0") >= 0)
  783. {
  784. string strSpeedWallFilter = json["P0"];
  785. nSpeedWallFilter = atoi(strSpeedWallFilter.c_str());
  786. out = "test@JSSetCSpeedWallFilter";
  787. ret = SetCSpeedWallFilter(nSpeedWallFilter);
  788. if (ret != RET_STATUS::RET_SUCCEED)
  789. {
  790. return ret;
  791. }
  792. m_EventCenter->OnNotify((int)ATTRACTION_SET, AttrKey::CSpeedWallFilter, strSpeedWallFilter);
  793. }
  794. return ret;
  795. }
  796. RET_STATUS nsFPD::AcqUnit::JSSetCRangeWallFilter(std::string in, std::string& out)
  797. {
  798. ResDataObject json;
  799. json.decode(in.c_str());
  800. int nRangeWallFilter = 0; //0-31
  801. Info("JSSetCRangeWallFilter {$}", in.c_str());
  802. RET_STATUS ret = RET_STATUS::RET_FAILED;
  803. if (json.GetFirstOf("P0") >= 0)
  804. {
  805. string strRangeWallFilter = json["P0"];
  806. nRangeWallFilter = atoi(strRangeWallFilter.c_str());
  807. out = "test@JSSetCRangeWallFilter";
  808. ret = SetCRangeWallFilter(nRangeWallFilter);
  809. if (ret != RET_STATUS::RET_SUCCEED)
  810. {
  811. return ret;
  812. }
  813. m_EventCenter->OnNotify((int)ATTRACTION_SET, AttrKey::CRangeWallFilter, strRangeWallFilter);
  814. }
  815. return ret;
  816. }
  817. RET_STATUS nsFPD::AcqUnit::JSSetCPersistence(std::string in, std::string& out)
  818. {
  819. ResDataObject json;
  820. json.decode(in.c_str());
  821. int nPersistence = 0; //0-9
  822. Info("JSSetCPersistence {$}", in.c_str());
  823. RET_STATUS ret = RET_STATUS::RET_FAILED;
  824. if (json.GetFirstOf("P0") >= 0)
  825. {
  826. string strPersistence = json["P0"];
  827. nPersistence = atoi(strPersistence.c_str());
  828. out = "test@JSSetCPersistence";
  829. ret = SetCPersistence(nPersistence);
  830. if (ret != RET_STATUS::RET_SUCCEED)
  831. {
  832. return ret;
  833. }
  834. m_EventCenter->OnNotify((int)ATTRACTION_SET, AttrKey::CPersistence, strPersistence);
  835. }
  836. return ret;
  837. }
  838. RET_STATUS nsFPD::AcqUnit::JSSetCLinearAngle(std::string in, std::string& out)
  839. {
  840. ResDataObject json;
  841. json.decode(in.c_str());
  842. int nAngle = 0;
  843. Info("JSSetCLinearAngle {$}", in.c_str());
  844. RET_STATUS ret = RET_STATUS::RET_FAILED;
  845. if (json.GetFirstOf("P0") >= 0)
  846. {
  847. string strAngle = json["P0"];
  848. nAngle = atoi(strAngle.c_str());
  849. out = "test@JSSetCLinearAngle";
  850. ret = SetCLinearAngle(nAngle);
  851. if (ret != RET_STATUS::RET_SUCCEED)
  852. {
  853. return ret;
  854. }
  855. m_EventCenter->OnNotify((int)ATTRACTION_SET, AttrKey::CLinearAngle, strAngle);
  856. }
  857. return ret;
  858. }
  859. RET_STATUS nsFPD::AcqUnit::JSSetCPrf(std::string in, std::string& out)
  860. {
  861. ResDataObject json;
  862. json.decode(in.c_str());
  863. int nPrf = 0;//0-15
  864. Info("JSSetCPrf {$}", in.c_str());
  865. RET_STATUS ret = RET_STATUS::RET_FAILED;
  866. if (json.GetFirstOf("P0") >= 0)
  867. {
  868. string strPrf = json["P0"];
  869. nPrf = atoi(strPrf.c_str());
  870. out = "test@JSSetCPrf";
  871. ret = SetCLinearAngle(nPrf);
  872. if (ret != RET_STATUS::RET_SUCCEED)
  873. {
  874. return ret;
  875. }
  876. m_EventCenter->OnNotify((int)ATTRACTION_SET, AttrKey::CPrf, strPrf);
  877. }
  878. return ret;
  879. }
  880. RET_STATUS nsFPD::AcqUnit::JSGetCFrequency(std::string in, std::string& out)
  881. {
  882. Info("JSGetCFrequency");
  883. float frequency = 0.0f;
  884. RET_STATUS ret = GetCFrequency(frequency);
  885. if (ret != RET_STATUS::RET_SUCCEED)
  886. {
  887. return ret;
  888. }
  889. ResDataObject json;
  890. std::string strFrequency = std::to_string(frequency);
  891. json.add(AttrKey::CFrequency, strFrequency.c_str());
  892. string result = json.encode();
  893. out = result;
  894. return ret;
  895. }
  896. RET_STATUS nsFPD::AcqUnit::JSGetCGain(std::string in, std::string& out)
  897. {
  898. Info("JSGetCGain");
  899. int nGain = 0;
  900. RET_STATUS ret = GetCGain(nGain);
  901. if (ret != RET_STATUS::RET_SUCCEED)
  902. {
  903. return ret;
  904. }
  905. ResDataObject json;
  906. std::string strGain = std::to_string(nGain);
  907. json.add(AttrKey::CGain, strGain.c_str());
  908. string result = json.encode();
  909. out = result;
  910. return ret;
  911. }
  912. RET_STATUS nsFPD::AcqUnit::JSGetCPrf(std::string in, std::string& out)
  913. {
  914. Info("JSGetCPrf");
  915. int nPrf = 0;
  916. RET_STATUS ret = GetCPrf(nPrf);
  917. if (ret != RET_STATUS::RET_SUCCEED)
  918. {
  919. return ret;
  920. }
  921. ResDataObject json;
  922. std::string strPrf = std::to_string(nPrf);
  923. json.add(AttrKey::CPrf, strPrf.c_str());
  924. string result = json.encode();
  925. out = result;
  926. return ret;
  927. }
  928. RET_STATUS nsFPD::AcqUnit::JSGetCLinearAngle(std::string in, std::string& out)
  929. {
  930. Info("JSGetCLinearAngle");
  931. int nAngle = 0;
  932. RET_STATUS ret = GetCLinearAngle(nAngle);
  933. if (ret != RET_STATUS::RET_SUCCEED)
  934. {
  935. return ret;
  936. }
  937. ResDataObject json;
  938. std::string strAngle = std::to_string(nAngle);
  939. json.add(AttrKey::CLinearAngle, strAngle.c_str());
  940. string result = json.encode();
  941. out = result;
  942. return ret;
  943. }
  944. RET_STATUS nsFPD::AcqUnit::JSSetTgc1(std::string in, std::string& out)
  945. {
  946. ResDataObject json;
  947. json.decode(in.c_str());
  948. int nTgc = 0;
  949. Info("JSSetTgc1 {$}", in.c_str());
  950. if (json.GetFirstOf("P0") >= 0)
  951. {
  952. string strTgc = json["P0"];
  953. nTgc = atoi(strTgc.c_str());
  954. }
  955. out = "test@JSSetTgc1";
  956. return SetTgc1(nTgc);
  957. }
  958. RET_STATUS nsFPD::AcqUnit::JSSetTgc2(std::string in, std::string& out)
  959. {
  960. ResDataObject json;
  961. json.decode(in.c_str());
  962. int nTgc = 0;
  963. Info("JSSetTgc2 {$}", in.c_str());
  964. if (json.GetFirstOf("P0") >= 0)
  965. {
  966. string strTgc = json["P0"];
  967. nTgc = atoi(strTgc.c_str());
  968. }
  969. out = "test@JSSetTgc2";
  970. return SetTgc2(nTgc);
  971. }
  972. RET_STATUS nsFPD::AcqUnit::JSSetTgc3(std::string in, std::string& out)
  973. {
  974. ResDataObject json;
  975. json.decode(in.c_str());
  976. int nTgc = 0;
  977. Info("JSSetTgc3 {$}", in.c_str());
  978. if (json.GetFirstOf("P0") >= 0)
  979. {
  980. string strTgc = json["P0"];
  981. nTgc = atoi(strTgc.c_str());
  982. }
  983. out = "test@JSSetTgc3";
  984. return SetTgc3(nTgc);
  985. }
  986. RET_STATUS nsFPD::AcqUnit::JSSetTgc4(std::string in, std::string& out)
  987. {
  988. ResDataObject json;
  989. json.decode(in.c_str());
  990. int nTgc = 0;
  991. Info("JSSetTgc4 {$}", in.c_str());
  992. if (json.GetFirstOf("P0") >= 0)
  993. {
  994. string strTgc = json["P0"];
  995. nTgc = atoi(strTgc.c_str());
  996. }
  997. out = "test@JSSetTgc4";
  998. return SetTgc4(nTgc);
  999. }
  1000. RET_STATUS nsFPD::AcqUnit::JSSetTgc5(std::string in, std::string& out)
  1001. {
  1002. ResDataObject json;
  1003. json.decode(in.c_str());
  1004. int nTgc = 0;
  1005. Info("JSSetTgc5 {$}", in.c_str());
  1006. if (json.GetFirstOf("P0") >= 0)
  1007. {
  1008. string strTgc = json["P0"];
  1009. nTgc = atoi(strTgc.c_str());
  1010. }
  1011. out = "test@JSSetTgc5";
  1012. return SetTgc5(nTgc);
  1013. }
  1014. RET_STATUS nsFPD::AcqUnit::JSSetTgc6(std::string in, std::string& out)
  1015. {
  1016. ResDataObject json;
  1017. json.decode(in.c_str());
  1018. int nTgc = 0;
  1019. Info("JSSetTgc6 {$}", in.c_str());
  1020. if (json.GetFirstOf("P0") >= 0)
  1021. {
  1022. string strTgc = json["P0"];
  1023. nTgc = atoi(strTgc.c_str());
  1024. }
  1025. out = "test@JSSetTgc6";
  1026. return SetTgc6(nTgc);
  1027. }
  1028. RET_STATUS nsFPD::AcqUnit::JSSetTgc7(std::string in, std::string& out)
  1029. {
  1030. ResDataObject json;
  1031. json.decode(in.c_str());
  1032. int nTgc = 0;
  1033. Info("JSSetTgc7 {$}", in.c_str());
  1034. if (json.GetFirstOf("P0") >= 0)
  1035. {
  1036. string strTgc = json["P0"];
  1037. nTgc = atoi(strTgc.c_str());
  1038. }
  1039. out = "test@JSSetTgc7";
  1040. return SetTgc7(nTgc);
  1041. }
  1042. RET_STATUS nsFPD::AcqUnit::JSSetTgc8(std::string in, std::string& out)
  1043. {
  1044. ResDataObject json;
  1045. json.decode(in.c_str());
  1046. int nTgc = 0;
  1047. Info("JSSetTgc8 {$}", in.c_str());
  1048. if (json.GetFirstOf("P0") >= 0)
  1049. {
  1050. string strTgc = json["P0"];
  1051. nTgc = atoi(strTgc.c_str());
  1052. }
  1053. out = "test@JSSetTgc8";
  1054. return SetTgc8(nTgc);
  1055. }
  1056. RET_STATUS nsFPD::AcqUnit::SetFreeze(int nFreeze)
  1057. {
  1058. return RET_STATUS::RET_SUCCEED;
  1059. }
  1060. RET_STATUS nsFPD::AcqUnit::SwitchProbe(int nProbeType)
  1061. {
  1062. return RET_STATUS::RET_SUCCEED;
  1063. }
  1064. RET_STATUS nsFPD::AcqUnit::SwitchProbeMode(int nProbeMode)
  1065. {
  1066. return RET_STATUS::RET_SUCCEED;
  1067. }
  1068. RET_STATUS nsFPD::AcqUnit::SetBGain(int nGain)
  1069. {
  1070. return RET_STATUS::RET_SUCCEED;
  1071. }
  1072. RET_STATUS nsFPD::AcqUnit::SetBDepth(int nDepth)
  1073. {
  1074. return RET_STATUS::RET_SUCCEED;
  1075. }
  1076. RET_STATUS nsFPD::AcqUnit::SetBFrequency(float fFrequency)
  1077. {
  1078. return RET_STATUS::RET_SUCCEED;
  1079. }
  1080. RET_STATUS nsFPD::AcqUnit::SetBFocus(int nFocus)
  1081. {
  1082. return RET_STATUS::RET_SUCCEED;
  1083. }
  1084. RET_STATUS nsFPD::AcqUnit::SetBHarmonic(int nHarmonic)
  1085. {
  1086. return RET_STATUS::RET_SUCCEED;
  1087. }
  1088. RET_STATUS nsFPD::AcqUnit::SetBPower(int nPower)
  1089. {
  1090. return RET_STATUS::RET_SUCCEED;
  1091. }
  1092. RET_STATUS nsFPD::AcqUnit::SetBDynamicRange(int nRange)
  1093. {
  1094. return RET_STATUS::RET_SUCCEED;
  1095. }
  1096. RET_STATUS nsFPD::AcqUnit::GetBDepth(int& nDepth, float& fDepthCm)
  1097. {
  1098. return RET_STATUS::RET_SUCCEED;
  1099. }
  1100. RET_STATUS nsFPD::AcqUnit::GetBFrequency(float& fFrequency)
  1101. {
  1102. return RET_STATUS::RET_SUCCEED;
  1103. }
  1104. RET_STATUS nsFPD::AcqUnit::GetBGain(int& nGain)
  1105. {
  1106. return RET_STATUS::RET_SUCCEED;
  1107. }
  1108. RET_STATUS nsFPD::AcqUnit::GetBFocus(int& nFocus, float& fFocusCm)
  1109. {
  1110. return RET_STATUS::RET_SUCCEED;
  1111. }
  1112. RET_STATUS nsFPD::AcqUnit::GetBDynamicRange(int& nRange)
  1113. {
  1114. return RET_STATUS::RET_SUCCEED;
  1115. }
  1116. RET_STATUS nsFPD::AcqUnit::SetCRoi(int x1, int x2, int y1, int y2)
  1117. {
  1118. return RET_STATUS::RET_SUCCEED;
  1119. }
  1120. RET_STATUS nsFPD::AcqUnit::SetCGain(int nGain)
  1121. {
  1122. return RET_STATUS::RET_SUCCEED;
  1123. }
  1124. RET_STATUS nsFPD::AcqUnit::SetPostLevel(int nLevel)
  1125. {
  1126. return RET_STATUS::RET_SUCCEED;
  1127. }
  1128. RET_STATUS nsFPD::AcqUnit::SetMirror(int nMirror)
  1129. {
  1130. return RET_STATUS::RET_SUCCEED;
  1131. }
  1132. RET_STATUS nsFPD::AcqUnit::SetCFrequency(float fFrequency)
  1133. {
  1134. return RET_STATUS::RET_SUCCEED;
  1135. }
  1136. RET_STATUS nsFPD::AcqUnit::SetCSpeedWallFilter(int nSpeedWallFilter)
  1137. {
  1138. return RET_STATUS::RET_SUCCEED;
  1139. }
  1140. RET_STATUS nsFPD::AcqUnit::SetCRangeWallFilter(int nRangeWallFilter)
  1141. {
  1142. return RET_STATUS::RET_SUCCEED;
  1143. }
  1144. RET_STATUS nsFPD::AcqUnit::SetCPersistence(int nPersistence)
  1145. {
  1146. return RET_STATUS::RET_SUCCEED;
  1147. }
  1148. RET_STATUS nsFPD::AcqUnit::SetCLinearAngle(int nAngle)
  1149. {
  1150. return RET_STATUS::RET_SUCCEED;
  1151. }
  1152. RET_STATUS nsFPD::AcqUnit::SetCPrf(int nPrf)
  1153. {
  1154. return RET_STATUS::RET_SUCCEED;
  1155. }
  1156. RET_STATUS nsFPD::AcqUnit::GetCFrequency(float& fFrequency)
  1157. {
  1158. return RET_STATUS::RET_SUCCEED;
  1159. }
  1160. RET_STATUS nsFPD::AcqUnit::GetCGain(int& nGain)
  1161. {
  1162. return RET_STATUS::RET_SUCCEED;
  1163. }
  1164. RET_STATUS nsFPD::AcqUnit::GetCPrf(int& nPrf)
  1165. {
  1166. return RET_STATUS::RET_SUCCEED;
  1167. }
  1168. RET_STATUS nsFPD::AcqUnit::GetCLinearAngle(int& nAngle)
  1169. {
  1170. return RET_STATUS::RET_SUCCEED;
  1171. }
  1172. RET_STATUS nsFPD::AcqUnit::SetTgc1(int nTgc)
  1173. {
  1174. return RET_STATUS::RET_SUCCEED;
  1175. }
  1176. RET_STATUS nsFPD::AcqUnit::SetTgc2(int nTgc)
  1177. {
  1178. return RET_STATUS::RET_SUCCEED;
  1179. }
  1180. RET_STATUS nsFPD::AcqUnit::SetTgc3(int nTgc)
  1181. {
  1182. return RET_STATUS::RET_SUCCEED;
  1183. }
  1184. RET_STATUS nsFPD::AcqUnit::SetTgc4(int nTgc)
  1185. {
  1186. return RET_STATUS::RET_SUCCEED;
  1187. }
  1188. RET_STATUS nsFPD::AcqUnit::SetTgc5(int nTgc)
  1189. {
  1190. return RET_STATUS::RET_SUCCEED;
  1191. }
  1192. RET_STATUS nsFPD::AcqUnit::SetTgc6(int nTgc)
  1193. {
  1194. return RET_STATUS::RET_SUCCEED;
  1195. }
  1196. RET_STATUS nsFPD::AcqUnit::SetTgc7(int nTgc)
  1197. {
  1198. return RET_STATUS::RET_SUCCEED;
  1199. }
  1200. RET_STATUS nsFPD::AcqUnit::SetTgc8(int nTgc)
  1201. {
  1202. return RET_STATUS::RET_SUCCEED;
  1203. }
  1204. void nsFPD::AcqUnit::NotifyProbeType(int nProbeType)
  1205. {
  1206. Info("NotifyProbeType nProbeType:{$}", nProbeType);
  1207. string probeType = std::to_string(nProbeType);
  1208. m_EventCenter->OnNotify((int)ATTRACTION_SET, AttrKey::ProbeType, probeType);
  1209. }