OTSSEMBruker.cpp 16 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602
  1. #include "stdafx.h"
  2. #include "OTSSEMBruker.h"
  3. namespace OTSController {
  4. // constructor
  5. COTSSEMBruker::COTSSEMBruker()
  6. : m_bConnected(FALSE)
  7. {
  8. }
  9. // destructor
  10. COTSSEMBruker::~COTSSEMBruker()
  11. {
  12. }
  13. // check if connected
  14. // return true if setup success
  15. BOOL COTSSEMBruker::IsConnected()
  16. {
  17. return m_bConnected;
  18. }
  19. // connect client dll
  20. BOOL COTSSEMBruker::Connect()
  21. {
  22. // doing nothing if m_pBrukerImplPtr is not nullptr
  23. if (!m_pBrukerImplPtr)
  24. {
  25. // get bruker initialize controller
  26. m_pBrukerImplPtr = COTSBrukerImpl::GetInstance();
  27. }
  28. // make sure m_pBrukerImplPtr is OK
  29. if (m_pBrukerImplPtr)
  30. {
  31. // initialize the bruker controller as a SEM controller
  32. if (m_pBrukerImplPtr->Init(CONTROL_TYPE::BRUKER_SEM))
  33. {
  34. // check connection
  35. if (!m_pBrukerImplPtr->CheckConnection(m_bConnected))
  36. {
  37. LogErrorTrace(__FILE__, __LINE__, _T("COTSSEMBruker::Connect: failed to call CheckConnection."));
  38. m_pBrukerImplPtr.reset();
  39. m_bConnected = FALSE;
  40. return FALSE;
  41. }
  42. }
  43. // connection is ok?
  44. if (!m_bConnected)
  45. {
  46. // connection
  47. LogErrorTrace(__FILE__, __LINE__, _T("COTSSEMBruker::Connect(): connecting failed."));
  48. m_pBrukerImplPtr.reset();
  49. return FALSE;
  50. }
  51. }
  52. // ok, return TRUE
  53. return TRUE;
  54. }
  55. // set beam blank
  56. BOOL COTSSEMBruker::SetBeamBlank(long a_nBeamBlank)
  57. {
  58. // m_pBrukerImplPtr check
  59. ASSERT(m_pBrukerImplPtr);
  60. if (!m_pBrukerImplPtr)
  61. {
  62. LogErrorTrace(__FILE__, __LINE__, _T("COTSSEMBruker::SetBeamBlank: m_pBrukerImplPtr is invalid."));
  63. return FALSE;
  64. }
  65. // turn Bean off if a_nBeamBlank > 0
  66. if (a_nBeamBlank > 0)
  67. {
  68. if (!m_pBrukerImplPtr->SwitchSEMOff(FALSE, FALSE, TRUE))
  69. {
  70. // failed to call SwitchSEMOff method
  71. LogErrorTrace(__FILE__, __LINE__, _T("COTSSEMBruker::SetBeamBlank : failed to call SwitchSEMOff method."));
  72. return FALSE;
  73. }
  74. }
  75. // ok, return TRUE
  76. return TRUE;
  77. }
  78. // brightness
  79. BOOL COTSSEMBruker::GetBrightness(double& a_dBrightness)
  80. {
  81. // m_pBrukerImplPtr check
  82. ASSERT(m_pBrukerImplPtr);
  83. if (!m_pBrukerImplPtr)
  84. {
  85. LogErrorTrace(__FILE__, __LINE__, _T("COTSSEMBruker::GetBrightness: m_pBrukerImplPtr is invalid."));
  86. return FALSE;
  87. }
  88. // get brightness and contrast
  89. double dBrightness, dContrast;
  90. if (!m_pBrukerImplPtr->GetSEMBCData(dBrightness, dContrast))
  91. {
  92. // failed to call GetSEMBCData method
  93. LogErrorTrace(__FILE__, __LINE__, _T("COTSSEMBruker::GetBrightness: failed to call GetSEMBCData method."));
  94. return FALSE;
  95. }
  96. a_dBrightness = dBrightness;
  97. // ok, return TRUE
  98. return TRUE;
  99. }
  100. BOOL COTSSEMBruker::SetBrightness(double a_dBrightness)
  101. {
  102. // m_pBrukerImplPtr check
  103. ASSERT(m_pBrukerImplPtr);
  104. if (!m_pBrukerImplPtr)
  105. {
  106. LogErrorTrace(__FILE__, __LINE__, _T("COTSSEMBruker::SetBrightness: m_pBrukerImplPtr is invalid."));
  107. return FALSE;
  108. }
  109. // get current brightness and contrast
  110. double dBrightness, dContrast;
  111. if (!m_pBrukerImplPtr->GetSEMBCData(dBrightness, dContrast))
  112. {
  113. // failed to call GetSEMBCData method
  114. LogErrorTrace(__FILE__, __LINE__, _T("COTSSEMBruker::SetBrightness: failed to call GetSEMBCData method."));
  115. return FALSE;
  116. }
  117. // set brightness and contrast
  118. dBrightness = a_dBrightness;
  119. if (!m_pBrukerImplPtr->SetSEMBCData(dBrightness, dContrast))
  120. {
  121. // failed to call GetSEMBCData method
  122. LogErrorTrace(__FILE__, __LINE__, _T("COTSSEMBruker::SetBrightness: failed to call SetSEMBCData method."));
  123. return FALSE;
  124. }
  125. // ok, return TRUE
  126. return TRUE;
  127. }
  128. // contrast
  129. BOOL COTSSEMBruker::GetContrast(double& a_dContrast)
  130. {
  131. // m_pBrukerImplPtr check
  132. ASSERT(m_pBrukerImplPtr);
  133. if (!m_pBrukerImplPtr)
  134. {
  135. LogErrorTrace(__FILE__, __LINE__, _T("COTSSEMBruker::GetContrast: m_pBrukerImplPtr is invalid."));
  136. return FALSE;
  137. }
  138. // get brightness and contrast
  139. double dBrightness, dContrast;
  140. if (!m_pBrukerImplPtr->GetSEMBCData(dBrightness, dContrast))
  141. {
  142. // failed to call GetSEMBCData method
  143. LogErrorTrace(__FILE__, __LINE__, _T("COTSSEMBruker::GetContrast: failed to call GetSEMBCData method."));
  144. return FALSE;
  145. }
  146. a_dContrast = dContrast;
  147. // ok, return TRUE
  148. return TRUE;
  149. }
  150. BOOL COTSSEMBruker::SetContrast(double a_dContrast)
  151. {
  152. // m_pBrukerImplPtr check
  153. ASSERT(m_pBrukerImplPtr);
  154. if (!m_pBrukerImplPtr)
  155. {
  156. LogErrorTrace(__FILE__, __LINE__, _T("COTSSEMBruker::SetContrast: m_pBrukerImplPtr is invalid."));
  157. return FALSE;
  158. }
  159. // get current brightness and contrast
  160. double dBrightness, dContrast;
  161. if (!m_pBrukerImplPtr->GetSEMBCData(dBrightness, dContrast))
  162. {
  163. // failed to call GetSEMBCData method
  164. LogErrorTrace(__FILE__, __LINE__, _T("COTSSEMBruker::SetContrast: failed to call GetSEMBCData method."));
  165. return FALSE;
  166. }
  167. // set brightness and contrast
  168. dContrast = a_dContrast;
  169. if (!m_pBrukerImplPtr->SetSEMBCData(dBrightness, dContrast))
  170. {
  171. // failed to call SetSEMBCData method
  172. LogErrorTrace(__FILE__, __LINE__, _T("COTSSEMBruker::SetContrast: failed to call SetSEMBCData method."));
  173. return FALSE;
  174. }
  175. // ok, return TRUE
  176. return TRUE;
  177. }
  178. // working distance
  179. BOOL COTSSEMBruker::GetWorkingDistance(double& a_dWorkingDistance)
  180. {
  181. // m_pBrukerImplPtr check
  182. ASSERT(m_pBrukerImplPtr);
  183. if (!m_pBrukerImplPtr)
  184. {
  185. LogErrorTrace(__FILE__, __LINE__, _T("COTSSEMBruker::GetWorkingDistance: m_pBrukerImplPtr is invalid."));
  186. return FALSE;
  187. }
  188. // get mag, KV and working distance
  189. double dMagnification, dHighVoltage, dWorkingDistance;
  190. if (!m_pBrukerImplPtr->GetSEMData(dMagnification, dHighVoltage, dWorkingDistance))
  191. {
  192. // failed to call GetSEMData method
  193. LogErrorTrace(__FILE__, __LINE__, _T("COTSSEMBruker::GetWorkingDistance: failed to call SetSEMData method."));
  194. return FALSE;
  195. }
  196. a_dWorkingDistance = dWorkingDistance;
  197. // ok, return TRUE
  198. return TRUE;
  199. }
  200. BOOL COTSSEMBruker::SetWorkingDistance(double a_dWorkingDistance)
  201. {
  202. // m_pBrukerImplPtr check
  203. ASSERT(m_pBrukerImplPtr);
  204. if (!m_pBrukerImplPtr)
  205. {
  206. LogErrorTrace(__FILE__, __LINE__, _T("COTSSEMBruker::SetWorkingDistance: m_pBrukerImplPtr is invalid."));
  207. return FALSE;
  208. }
  209. // get current mag, KV and working distance
  210. double dMagnification, dHighVoltage, dWorkingDistance;
  211. if (!m_pBrukerImplPtr->GetSEMData(dMagnification, dHighVoltage, dWorkingDistance))
  212. {
  213. // failed to call GetSEMData method
  214. LogErrorTrace(__FILE__, __LINE__, _T("COTSSEMBruker::SetWorkingDistance: failed to call GetSEMData method."));
  215. return FALSE;
  216. }
  217. // set mag, KV and working distance
  218. dWorkingDistance = a_dWorkingDistance;
  219. if (!m_pBrukerImplPtr->SetSEMData(dMagnification, dHighVoltage, dWorkingDistance))
  220. {
  221. // failed to call SetSEMData method
  222. LogErrorTrace(__FILE__, __LINE__, _T("COTSSEMBruker::SetWorkingDistance: failed to call SetSEMData method."));
  223. return FALSE;
  224. }
  225. // ok, return TRUE
  226. return TRUE;
  227. }
  228. // high tension (KV)
  229. BOOL COTSSEMBruker::GetHighTension(double& a_dKV)
  230. {
  231. // m_pBrukerImplPtr check
  232. ASSERT(m_pBrukerImplPtr);
  233. if (!m_pBrukerImplPtr)
  234. {
  235. LogErrorTrace(__FILE__, __LINE__, _T("COTSSEMBruker::GetHighTension: m_pBrukerImplPtr is invalid."));
  236. return FALSE;
  237. }
  238. // get mag, KV and working distance
  239. double dMagnification, dHighVoltage, dWorkingDistance;
  240. if (!m_pBrukerImplPtr->GetSEMData(dMagnification, dHighVoltage, dWorkingDistance))
  241. {
  242. // failed to call GetSEMData method
  243. LogErrorTrace(__FILE__, __LINE__, _T("COTSSEMBruker::GetHighTension: failed to call SetSEMData method."));
  244. return FALSE;
  245. }
  246. a_dKV = dHighVoltage;
  247. // ok, return TRUE
  248. return TRUE;
  249. }
  250. BOOL COTSSEMBruker::SetHighTension(double a_dKV)
  251. {
  252. // m_pBrukerImplPtr check
  253. ASSERT(m_pBrukerImplPtr);
  254. if (!m_pBrukerImplPtr)
  255. {
  256. LogErrorTrace(__FILE__, __LINE__, _T("COTSSEMBruker::SetHighTension: m_pBrukerImplPtr is invalid."));
  257. return FALSE;
  258. }
  259. // get current mag, KV and working distance
  260. double dMagnification, dHighVoltage, dWorkingDistance;
  261. if (!m_pBrukerImplPtr->GetSEMData(dMagnification, dHighVoltage, dWorkingDistance))
  262. {
  263. // failed to call GetSEMData method
  264. LogErrorTrace(__FILE__, __LINE__, _T("COTSSEMBruker::SetHighTension: failed to call GetSEMData method."));
  265. return FALSE;
  266. }
  267. // set mag, KV and working distance
  268. dHighVoltage = a_dKV;
  269. if (!m_pBrukerImplPtr->SetSEMData(dMagnification, dHighVoltage, dWorkingDistance))
  270. {
  271. // failed to call SetSEMData method
  272. LogErrorTrace(__FILE__, __LINE__, _T("COTSSEMBruker::SetHighTension: failed to call SetSEMData method."));
  273. return FALSE;
  274. }
  275. // ok, return TRUE
  276. return TRUE;
  277. }
  278. // magnification
  279. BOOL COTSSEMBruker::GetMagnification(double& a_dMagnification)
  280. {
  281. // m_pBrukerImplPtr check
  282. ASSERT(m_pBrukerImplPtr);
  283. if (!m_pBrukerImplPtr)
  284. {
  285. LogErrorTrace(__FILE__, __LINE__, _T("COTSSEMBruker::GetMagnification: m_pBrukerImplPtr is invalid."));
  286. return FALSE;
  287. }
  288. // get mag, KV and working distance
  289. double dMagnification, dHighVoltage, dWorkingDistance;
  290. if (!m_pBrukerImplPtr->GetSEMData(dMagnification, dHighVoltage, dWorkingDistance))
  291. {
  292. // failed to call GetSEMData method
  293. LogErrorTrace(__FILE__, __LINE__, _T("COTSSEMBruker::GetMagnification: failed to call SetSEMData method."));
  294. return FALSE;
  295. }
  296. a_dMagnification = dMagnification;
  297. // ok, return TRUE
  298. return TRUE;
  299. }
  300. BOOL COTSSEMBruker::SetMagnification(double a_dMagnification)
  301. {
  302. // m_pBrukerImplPtr check
  303. ASSERT(m_pBrukerImplPtr);
  304. if (!m_pBrukerImplPtr)
  305. {
  306. LogErrorTrace(__FILE__, __LINE__, _T("COTSSEMBruker::SetMagnification: m_pBrukerImplPtr is invalid."));
  307. return FALSE;
  308. }
  309. // get current mag, KV and working distance
  310. double dMagnification, dHighVoltage, dWorkingDistance;
  311. if (!m_pBrukerImplPtr->GetSEMData(dMagnification, dHighVoltage, dWorkingDistance))
  312. {
  313. // failed to call GetSEMData method
  314. LogErrorTrace(__FILE__, __LINE__, _T("COTSSEMBruker::SetMagnification: failed to call GetSEMData method."));
  315. return FALSE;
  316. }
  317. // set mag, KV and working distance
  318. dMagnification = a_dMagnification;
  319. if (!m_pBrukerImplPtr->SetSEMData(dMagnification, dHighVoltage, dWorkingDistance))
  320. {
  321. // failed to call SetSEMData method
  322. LogErrorTrace(__FILE__, __LINE__, _T("COTSSEMBruker::SetMagnification: failed to call SetSEMData method."));
  323. return FALSE;
  324. }
  325. // ok, return TRUE
  326. return TRUE;
  327. }
  328. // scan field size
  329. BOOL COTSSEMBruker::GetScanFieldSize(double& a_dScanFieldSizeX, double& a_dScanFieldSizeY)
  330. {
  331. // get magnification
  332. double dMag = 0;
  333. if (!GetMagnification(dMag))
  334. {
  335. // failed to call GetMagnification method
  336. LogErrorTrace(__FILE__, __LINE__, _T("COTSSEMBruker::GetScanFieldSize: failed to call GetMagnification method."));
  337. return FALSE;
  338. }
  339. // calculate scan field size
  340. double dScanFieldSizeX, dScanFieldSizeY;
  341. if (!MagToScanFieldSize(dMag, dScanFieldSizeX, dScanFieldSizeY))
  342. {
  343. // failed to call MagToScanFieldSize method
  344. LogErrorTrace(__FILE__, __LINE__, _T("COTSSEMBruker::GetScanFieldSize: failed to call MagToScanFieldSize method."));
  345. return FALSE;
  346. }
  347. // calculate scan field size and set output values
  348. a_dScanFieldSizeX = dScanFieldSizeX;
  349. a_dScanFieldSizeY = dScanFieldSizeY;
  350. // ok, return TRUE
  351. return TRUE;
  352. }
  353. BOOL COTSSEMBruker::SetScanFieldSizeX(double a_dScanFieldSizeX)
  354. {
  355. // calculate magnification
  356. double dMag = 0;
  357. if (!ScanFieldSizeToMag(dMag, a_dScanFieldSizeX))
  358. {
  359. // failed to call ScanFieldSizeToMag method
  360. LogErrorTrace(__FILE__, __LINE__, _T("COTSSEMBruker::SetScanFieldSizeX: filed to call ScanFieldSizeToMag method."));
  361. return FALSE;
  362. }
  363. // set magnification
  364. if(!SetMagnification(dMag))
  365. {
  366. // failed to call ScanFieldSizeToMag method
  367. LogErrorTrace(__FILE__, __LINE__, _T("COTSSEMBruker::SetScanFieldSizeX: filed to call SetMagnification method."));
  368. return FALSE;
  369. }
  370. // ok, return TRUE
  371. return TRUE;
  372. }
  373. // high tension off
  374. // note: a_bHTValue is FALSE will turn HT off
  375. BOOL COTSSEMBruker::SetHTOnOff(BOOL a_bHTValue)
  376. {
  377. // m_pBrukerImplPtr check
  378. ASSERT(m_pBrukerImplPtr);
  379. if (!m_pBrukerImplPtr)
  380. {
  381. LogErrorTrace(__FILE__, __LINE__, _T("COTSSEMBruker::SetHTOnOff: m_pBrukerImplPtr is invalid."));
  382. return FALSE;
  383. }
  384. // turn HT off if a_bHTValue is FALSE
  385. if (!a_bHTValue)
  386. {
  387. if (!m_pBrukerImplPtr->SwitchSEMOff(TRUE, FALSE, FALSE))
  388. {
  389. // failed to call SwitchSEMOff method
  390. LogErrorTrace(__FILE__, __LINE__, _T("COTSSEMBruker::SetHTOnOff : failed to call SwitchSEMOff method."));
  391. return FALSE;
  392. }
  393. }
  394. // ok, return TRUE
  395. return TRUE;
  396. }
  397. // position
  398. BOOL COTSSEMBruker::GetPositionXY(double& a_dPositionX, double& a_dPositionY, double& a_dPositionR)
  399. {
  400. // m_pBrukerImplPtr check
  401. ASSERT(m_pBrukerImplPtr);
  402. if (!m_pBrukerImplPtr)
  403. {
  404. LogErrorTrace(__FILE__, __LINE__, _T("COTSSEMBruker::GetPositionXY: m_pBrukerImplPtr is invalid."));
  405. return FALSE;
  406. }
  407. // get position
  408. double dPositionX, dPositionY, dPositionZ, dTilt, dRotation;
  409. if (!m_pBrukerImplPtr->GetSEMStageData(dPositionX, dPositionY, dPositionZ, dTilt, dRotation))
  410. {
  411. // failed to call GetSEMStageData method
  412. LogErrorTrace(__FILE__, __LINE__, _T("COTSSEMBruker::GetPositionXY : failed to call GetSEMStageData method."));
  413. return FALSE;
  414. }
  415. // need to convert dPositionX, dPositionY from SEM position to OTS position
  416. // set output values
  417. a_dPositionX = dPositionX;
  418. a_dPositionY = dPositionY;
  419. a_dPositionR = dRotation;
  420. // ok, return TRUE
  421. return TRUE;
  422. }
  423. BOOL COTSSEMBruker::SetPositionXY(double a_dPositionX, double a_dPositionY, double a_dPositionR)
  424. {
  425. // m_pBrukerImplPtr check
  426. ASSERT(m_pBrukerImplPtr);
  427. if (!m_pBrukerImplPtr)
  428. {
  429. LogErrorTrace(__FILE__, __LINE__, _T("COTSSEMBruker::SetPositionXY: m_pBrukerImplPtr is invalid."));
  430. return FALSE;
  431. }
  432. // get position
  433. double dPositionX, dPositionY, dPositionZ, dTilt, dRotation;
  434. if (!m_pBrukerImplPtr->GetSEMStageData(dPositionX, dPositionY, dPositionZ, dTilt, dRotation))
  435. {
  436. // failed to call GetSEMStageData method
  437. LogErrorTrace(__FILE__, __LINE__, _T("COTSSEMBruker::SetPositionXY : failed to call GetSEMStageData method."));
  438. return FALSE;
  439. }
  440. // need to convert a_dPositionX, a_dPositionY from OTS position to SEM position
  441. // set position
  442. dPositionX = a_dPositionX;
  443. dPositionY = a_dPositionY;
  444. dRotation = a_dPositionR;
  445. LogTrace(__FILE__, __LINE__, _T("COTSSEMBruker::Start to SetPositionXY "));
  446. if (!m_pBrukerImplPtr->SetSEMStageData(dPositionX, dPositionY, dPositionZ, dTilt, dRotation))
  447. {
  448. // failed to call SetSEMStageData method
  449. LogErrorTrace(__FILE__, __LINE__, _T("COTSSEMBruker::SetPositionXY : failed to call SetSEMStageData method."));
  450. return FALSE;
  451. }
  452. LogTrace(__FILE__, __LINE__, _T("COTSSEMBruker::Finished SetPositionXY "));
  453. // ok, return TRUE
  454. return TRUE;
  455. }
  456. // spot size
  457. BOOL COTSSEMBruker::GetSpotSize(double& a_dSpotSize)
  458. {
  459. // m_pBrukerImplPtr check
  460. ASSERT(m_pBrukerImplPtr);
  461. if (!m_pBrukerImplPtr)
  462. {
  463. LogErrorTrace(__FILE__, __LINE__, _T("COTSSEMBruker::GetSpotSize: m_pBrukerImplPtr is invalid."));
  464. return FALSE;
  465. }
  466. // get spot size
  467. double dSpotSize;
  468. if (!m_pBrukerImplPtr->GetSEMSpotSize(dSpotSize))
  469. {
  470. // failed to call GetSEMSpotSize method
  471. LogErrorTrace(__FILE__, __LINE__, _T("COTSSEMBruker::GetSpotSize : failed to call GetSEMSpotSize method."));
  472. return FALSE;
  473. }
  474. a_dSpotSize = dSpotSize;
  475. // ok, return TRUE
  476. return TRUE;
  477. }
  478. BOOL COTSSEMBruker::SetSpotSize(double a_dSpotSize)
  479. {
  480. // m_pBrukerImplPtr check
  481. ASSERT(m_pBrukerImplPtr);
  482. if (!m_pBrukerImplPtr)
  483. {
  484. LogErrorTrace(__FILE__, __LINE__, _T("COTSSEMBruker::SetSpotSize: m_pBrukerImplPtr is invalid."));
  485. return FALSE;
  486. }
  487. // set spot size
  488. if (!m_pBrukerImplPtr->SetSEMSpotSize(a_dSpotSize))
  489. {
  490. // failed to call GetSEMSpotSize method
  491. LogErrorTrace(__FILE__, __LINE__, _T("COTSSEMBruker::SetSpotSize : failed to call SetSEMSpotSize method."));
  492. return FALSE;
  493. }
  494. // ok, return TRUE
  495. return TRUE;
  496. }
  497. // external mode
  498. BOOL COTSSEMBruker::SetScanExternal(BOOL a_bExternalOn)
  499. {
  500. // m_pBrukerImplPtr check
  501. ASSERT(m_pBrukerImplPtr);
  502. if (!m_pBrukerImplPtr)
  503. {
  504. LogErrorTrace(__FILE__, __LINE__, _T("COTSSEMBruker::SetScanExternal: m_pBrukerImplPtr is invalid."));
  505. return FALSE;
  506. }
  507. if (a_bExternalOn)
  508. {
  509. // turn external on
  510. if (!m_pBrukerImplPtr->SetSEMExternalOn())
  511. {
  512. // failed to call GetSEMSpotSize method
  513. LogErrorTrace(__FILE__, __LINE__, _T("COTSSEMBruker::SetScanExternal: failed to call SetSEMExternalOn method."));
  514. return FALSE;
  515. }
  516. }
  517. else
  518. {
  519. // turn external off
  520. if (!m_pBrukerImplPtr->SetSEMExternalOff())
  521. {
  522. // failed to call SetSEMExternalOff method
  523. LogErrorTrace(__FILE__, __LINE__, _T("COTSSEMBruker::SetScanExternal: failed to call SetSEMExternalOff method."));
  524. return FALSE;
  525. }
  526. }
  527. // ok, return TRUE
  528. return TRUE;
  529. }
  530. }