SmartSEM.cs 33 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495969798991001011021031041051061071081091101111121131141151161171181191201211221231241251261271281291301311321331341351361371381391401411421431441451461471481491501511521531541551561571581591601611621631641651661671681691701711721731741751761771781791801811821831841851861871881891901911921931941951961971981992002012022032042052062072082092102112122132142152162172182192202212222232242252262272282292302312322332342352362372382392402412422432442452462472482492502512522532542552562572582592602612622632642652662672682692702712722732742752762772782792802812822832842852862872882892902912922932942952962972982993003013023033043053063073083093103113123133143153163173183193203213223233243253263273283293303313323333343353363373383393403413423433443453463473483493503513523533543553563573583593603613623633643653663673683693703713723733743753763773783793803813823833843853863873883893903913923933943953963973983994004014024034044054064074084094104114124134144154164174184194204214224234244254264274284294304314324334344354364374384394404414424434444454464474484494504514524534544554564574584594604614624634644654664674684694704714724734744754764774784794804814824834844854864874884894904914924934944954964974984995005015025035045055065075085095105115125135145155165175185195205215225235245255265275285295305315325335345355365375385395405415425435445455465475485495505515525535545555565575585595605615625635645655665675685695705715725735745755765775785795805815825835845855865875885895905915925935945955965975985996006016026036046056066076086096106116126136146156166176186196206216226236246256266276286296306316326336346356366376386396406416426436446456466476486496506516526536546556566576586596606616626636646656666676686696706716726736746756766776786796806816826836846856866876886896906916926936946956966976986997007017027037047057067077087097107117127137147157167177187197207217227237247257267277287297307317327337347357367377387397407417427437447457467477487497507517527537547557567577587597607617627637647657667677687697707717727737747757767777787797807817827837847857867877887897907917927937947957967977987998008018028038048058068078088098108118128138148158168178188198208218228238248258268278288298308318328338348358368378388398408418428438448458468478488498508518528538548558568578588598608618628638648658668678688698708718728738748758768778788798808818828838848858868878888898908918928938948958968978988999009019029039049059069079089099109119129139149159169179189199209219229239249259269279289299309319329339349359369379389399409419429439449459469479489499509519529539549559569579589599609619629639649659669679689699709719729739749759769779789799809819829839849859869879889899909919929939949959969979989991000100110021003100410051006100710081009101010111012101310141015101610171018101910201021102210231024102510261027102810291030103110321033103410351036103710381039104010411042104310441045104610471048104910501051105210531054105510561057105810591060106110621063106410651066106710681069107010711072107310741075107610771078107910801081108210831084108510861087108810891090109110921093109410951096109710981099110011011102110311041105110611071108110911101111111211131114111511161117111811191120112111221123112411251126112711281129113011311132113311341135113611371138113911401141114211431144114511461147114811491150115111521153115411551156115711581159116011611162116311641165116611671168116911701171117211731174117511761177117811791180118111821183118411851186118711881189119011911192119311941195119611971198119912001201120212031204120512061207120812091210121112121213121412151216121712181219
  1. //时间:20200610
  2. //作者:王琦
  3. //功能:SmartSEM remote API控制
  4. using System;
  5. using System.Collections.Generic;
  6. using System.Linq;
  7. using System.Runtime.InteropServices;
  8. using System.Text;
  9. using System.Threading.Tasks;
  10. using APILib;
  11. using System.Threading;
  12. namespace SmartSEMControl
  13. {
  14. //可能遇到的错误提示部分??在log加入之后添加
  15. class SmartSEM : ISEMControl
  16. {
  17. #region 模拟参数
  18. //放大缩小
  19. private String AP_MAG = "AP_MAG";
  20. //焦距
  21. private String AP_WD = "AP_WD";
  22. //亮度
  23. private String AP_BRIGHTNESS = "AP_BRIGHTNESS";
  24. //对比度
  25. private String AP_CONTRAST = "AP_CONTRAST";
  26. //亮度目标
  27. private String AP_AUTO_BRIGHT = "AP_AUTO_BRIGHT";
  28. //对比度目标
  29. private String AP_AUTO_CONTRAST = "AP_AUTO_CONTRAST";
  30. //消像散X轴
  31. private String AP_STIG_X = "AP_STIG_X";
  32. //消像散Y轴
  33. private String AP_STIG_Y = "AP_STIG_Y";
  34. //角度补偿
  35. private String AP_TILT_ANGLE = "AP_TILT_ANGLE";
  36. //SEM移动X
  37. private String AP_BEAMSHIFT_X = "AP_BEAMSHIFT_X";
  38. //SEM移动Y
  39. private String AP_BEAMSHIFT_Y = "AP_BEAMSHIFT_Y";
  40. //X轴移动到
  41. private String AP_STAGE_GOTO_X = "AP_STAGE_GOTO_X";
  42. //Y轴移动到
  43. private String AP_STAGE_GOTO_Y = "AP_STAGE_GOTO_Y";
  44. //Z轴移动到
  45. private String AP_STAGE_GOTO_Z = "AP_STAGE_GOTO_Z";
  46. //T轴移动到
  47. private String AP_STAGE_GOTO_T = "AP_STAGE_GOTO_T";
  48. //R轴移动到
  49. private String AP_STAGE_GOTO_R = "AP_STAGE_GOTO_R";
  50. //M轴移动到
  51. private String AP_STAGE_GOTO_M = "AP_STAGE_GOTO_M";
  52. //Scan Rotate角度
  53. private String AP_SCANROTATION = "AP_SCANROTATION";
  54. //像素大小
  55. private String AP_PIXEL_SIZE = "AP_PIXEL_SIZE";
  56. //X轴坐标
  57. private String AP_STAGE_AT_X = "AP_STAGE_AT_X";
  58. //Y轴坐标
  59. private String AP_STAGE_AT_Y = "AP_STAGE_AT_Y";
  60. //Z轴坐标
  61. private String AP_STAGE_AT_Z = "AP_STAGE_AT_Z";
  62. //T轴坐标
  63. private String AP_STAGE_AT_T = "AP_STAGE_AT_T";
  64. //R轴坐标
  65. private String AP_STAGE_AT_R = "AP_STAGE_AT_R";
  66. //M轴坐标
  67. private String AP_STAGE_AT_M = "AP_STAGE_AT_M";
  68. #endregion
  69. #region 数字参数
  70. //Scan Rotate开关
  71. private String DP_SCAN_ROT = "DP_SCAN_ROT";
  72. //取消电子束校正
  73. private String DP_TILT_CORRECTION = "DP_TILT_CORRECTION";
  74. //自动亮度对比度
  75. private String DP_AUTO_VIDEO = "DP_AUTO_VIDEO";
  76. //图像解冻
  77. private String DP_FROZEN = "DP_FROZEN";
  78. //图像类型切换
  79. private String DP_DETECTOR_TYPE = "DP_DETECTOR_TYPE";
  80. //图像大小
  81. private String DP_IMAGE_STORE = "DP_IMAGE_STORE";
  82. //样品台状态
  83. private String DP_STAGE_IS = "DP_STAGE_IS";
  84. //自动函数状态
  85. private String DP_AUTO_FUNCTION = "DP_AUTO_FUNCTION";
  86. #endregion
  87. #region 命令
  88. //开启电压
  89. private String CMD_BEAM_ON = "CMD_BEAM_ON";
  90. //关闭电压
  91. private String CMD_EHT_OFF = "CMD_EHT_OFF";
  92. //自动对焦1
  93. private String CMD_AUTO_FOCUS_COARSE = "CMD_AUTO_FOCUS_COARSE";
  94. //自动对焦2
  95. private String CMD_AUTO_FOCUS_FINE = "CMD_AUTO_FOCUS_FINE";
  96. //自动消像散
  97. private String CMD_AUTO_STIG = "CMD_AUTO_STIG";
  98. //样品台急停
  99. private String CMD_STAGE_ABORT = "CMD_STAGE_ABORT";
  100. #endregion
  101. #region 宏文件命令
  102. private String MCF_FILENAME = "MCF_";
  103. #endregion
  104. #region APILib
  105. private Api CZEMApi = new Api();
  106. private Boolean m_bInitialised = false;
  107. #endregion
  108. #region 构造函数
  109. public SmartSEM()
  110. {
  111. Init();
  112. }
  113. #endregion
  114. #region 设备初始化
  115. /// <summary>
  116. /// 设备初始化
  117. /// </summary>
  118. /// <returns>return:true or false</returns>
  119. public Boolean Init()
  120. {
  121. long lrt = 0;
  122. #if ROMOTE
  123. lrt = CZEMApi.InitialiseRemoting();
  124. #else
  125. lrt = CZEMApi.Initialise("");
  126. #endif
  127. if (lrt != 0)
  128. {
  129. m_bInitialised = false;
  130. return false;
  131. }
  132. else
  133. {
  134. m_bInitialised = true;
  135. return true;
  136. }
  137. }
  138. #endregion
  139. #region 设备远程初始化
  140. /// <summary>
  141. /// 设备远程初始化
  142. /// </summary>
  143. /// <returns>return:true or false</returns>
  144. public Boolean InitRemoting()
  145. {
  146. long lrt = CZEMApi.InitialiseRemoting();
  147. if (lrt != 0)
  148. {
  149. m_bInitialised = false;
  150. return false;
  151. }
  152. else
  153. {
  154. m_bInitialised = true;
  155. return true;
  156. }
  157. }
  158. #endregion
  159. #region 连接状态
  160. public Boolean ConnectStatus()
  161. {
  162. return m_bInitialised;
  163. }
  164. #endregion
  165. #region 关闭设备
  166. /// <summary>
  167. /// 关闭设备
  168. /// </summary>
  169. /// <returns>true or false</returns>
  170. public Boolean Dispose()
  171. {
  172. if (m_bInitialised)
  173. {
  174. long lrt = CZEMApi.ClosingControl();
  175. if (lrt != 0)
  176. {
  177. return false;
  178. }
  179. else
  180. {
  181. m_bInitialised = false;
  182. return true;
  183. }
  184. }
  185. else
  186. {
  187. return false;
  188. }
  189. }
  190. #endregion
  191. #region 读参数函数
  192. private Boolean ReadParams(String str_param, ref float value)
  193. {
  194. if (m_bInitialised)
  195. {
  196. object varfloat = new VariantWrapper((float)0.0f);
  197. long lrt = CZEMApi.Get(str_param, ref varfloat);
  198. if (lrt != 0)
  199. {
  200. return false;
  201. }
  202. else
  203. {
  204. value = Convert.ToSingle(varfloat);
  205. return true;
  206. }
  207. }
  208. else
  209. {
  210. return false;
  211. }
  212. }
  213. #endregion
  214. #region 写模拟参数函数
  215. private Boolean WriteParams(String str_param, float value)
  216. {
  217. if (m_bInitialised)
  218. {
  219. //先取范围
  220. object varMin = new VariantWrapper((float)0.0f);
  221. object varMax = new VariantWrapper((float)0.0f);
  222. long lrt = CZEMApi.GetLimits(str_param, ref varMin, ref varMax);
  223. if (lrt != 0)
  224. {
  225. return false;
  226. }
  227. if (value <= Convert.ToSingle(varMax) && value >= Convert.ToSingle(varMin))
  228. {
  229. object varFloat = new VariantWrapper(value);
  230. lrt = CZEMApi.Set(str_param, ref varFloat);// set value
  231. if (lrt != 0)
  232. {
  233. return false;
  234. }
  235. return true;
  236. }
  237. else
  238. {
  239. return false;
  240. }
  241. }
  242. else
  243. {
  244. return false;
  245. }
  246. }
  247. #endregion
  248. #region 写数字参数函数
  249. private Boolean WriteDataParams(String str_param, float value)
  250. {
  251. if (m_bInitialised)
  252. {
  253. object varFloat = new VariantWrapper(value);
  254. long lrt = CZEMApi.Set(str_param, ref varFloat);// set value
  255. if (lrt != 0)
  256. {
  257. return false;
  258. }
  259. return true;
  260. }
  261. else
  262. {
  263. return false;
  264. }
  265. }
  266. #endregion
  267. #region 执行命令
  268. private Boolean ExecuteCmd(String cmd)
  269. {
  270. if (m_bInitialised)
  271. {
  272. long lrt = CZEMApi.Execute(cmd);// execute command
  273. if (lrt != 0)
  274. {
  275. return false;
  276. }
  277. else
  278. {
  279. return true;
  280. }
  281. }
  282. else
  283. {
  284. return false;
  285. }
  286. }
  287. #endregion
  288. #region 放大缩小
  289. /// <summary>
  290. /// 读取缩放倍数
  291. /// </summary>
  292. /// <returns>true:float or false:NaN</returns>
  293. public float GetMagnification()
  294. {
  295. float ret = 0;
  296. if(ReadParams(AP_MAG, ref ret))
  297. {
  298. return ret;
  299. }
  300. else
  301. {
  302. return float.NaN;
  303. }
  304. }
  305. /// <summary>
  306. /// 设置缩放倍数
  307. /// </summary>
  308. /// <param name="set">倍数</param>
  309. /// <returns>true or false</returns>
  310. public Boolean SetMagnification(float set)
  311. {
  312. return WriteParams(AP_MAG, set);
  313. }
  314. #endregion
  315. #region 焦距
  316. /// <summary>
  317. /// 读取工作距离
  318. /// </summary>
  319. /// <returns>true:float or false:NaN</returns>
  320. public float GetWorkingDistance()
  321. {
  322. float ret = 0;
  323. if (ReadParams(AP_WD, ref ret))
  324. {
  325. return ret;
  326. }
  327. else
  328. {
  329. return float.NaN;
  330. }
  331. }
  332. /// <summary>
  333. /// 设置焦距
  334. /// </summary>
  335. /// <param name="set">焦距</param>
  336. /// <returns>true or false</returns>
  337. public Boolean SetWorkingDistance(float set)
  338. {
  339. return WriteParams(AP_WD, set);
  340. }
  341. #endregion
  342. #region 亮度
  343. /// <summary>
  344. /// 读取亮度
  345. /// </summary>
  346. /// <returns>true:float or false:NaN</returns>
  347. public float GetBrightness()
  348. {
  349. float ret = 0;
  350. if (ReadParams(AP_BRIGHTNESS, ref ret))
  351. {
  352. return ret;
  353. }
  354. else
  355. {
  356. return float.NaN;
  357. }
  358. }
  359. /// <summary>
  360. /// 设置亮度
  361. /// </summary>
  362. /// <param name="set">亮度</param>
  363. /// <returns>true or false</returns>
  364. public Boolean SetBrightness(float set)
  365. {
  366. return WriteParams(AP_BRIGHTNESS, set);
  367. }
  368. #endregion
  369. #region 对比度
  370. /// <summary>
  371. /// 读取对比度
  372. /// </summary>
  373. /// <returns>true:float or false:NaN</returns>
  374. public float GetContrast()
  375. {
  376. float ret = 0;
  377. if (ReadParams(AP_CONTRAST, ref ret))
  378. {
  379. return ret;
  380. }
  381. else
  382. {
  383. return float.NaN;
  384. }
  385. }
  386. /// <summary>
  387. /// 设置对比度
  388. /// </summary>
  389. /// <param name="set">对比度</param>
  390. /// <returns>true or false</returns>
  391. public Boolean SetContrast(float set)
  392. {
  393. return WriteParams(AP_CONTRAST, set);
  394. }
  395. #endregion
  396. #region 自动亮度对比度
  397. /// <summary>
  398. /// 读取自动亮度对比度状态
  399. /// </summary>
  400. /// <returns>true:float or false:NaN</returns>
  401. public float GetAutoVideo()
  402. {
  403. float ret = 0;
  404. if (ReadParams(DP_AUTO_VIDEO, ref ret))
  405. {
  406. return ret;
  407. }
  408. else
  409. {
  410. return float.NaN;
  411. }
  412. }
  413. /// <summary>
  414. /// 设置自动亮度对比度状态
  415. /// </summary>
  416. /// <param name="set">0:off;1:B(亮度);2:C(对比度);3:BC</param>
  417. /// <returns>true or false</returns>
  418. public Boolean SetAutoVideoOff()
  419. {
  420. return WriteDataParams(DP_AUTO_VIDEO, (float)0);
  421. }
  422. public Boolean SetAutoVideoBrightness()
  423. {
  424. return WriteDataParams(DP_AUTO_VIDEO, (float)1);
  425. }
  426. public Boolean SetAutoVideoContrast()
  427. {
  428. return WriteDataParams(DP_AUTO_VIDEO, (float)2);
  429. }
  430. public Boolean SetAutoVideoBrightnessAndContrast()
  431. {
  432. return WriteDataParams(DP_AUTO_VIDEO, (float)3);
  433. }
  434. #endregion
  435. #region 亮度目标
  436. /// <summary>
  437. /// 读取亮度目标
  438. /// </summary>
  439. /// <returns>true:float or false:NaN</returns>
  440. public float GetAutoBright()
  441. {
  442. float ret = 0;
  443. if (ReadParams(AP_AUTO_BRIGHT, ref ret))
  444. {
  445. return ret;
  446. }
  447. else
  448. {
  449. return float.NaN;
  450. }
  451. }
  452. /// <summary>
  453. /// 设置亮度目标
  454. /// </summary>
  455. /// <param name="set">亮度</param>
  456. /// <returns>true or false</returns>
  457. public Boolean SetAutoBright(float set)
  458. {
  459. return WriteParams(AP_AUTO_BRIGHT, set);
  460. }
  461. #endregion
  462. #region 对比度目标
  463. /// <summary>
  464. /// 读取对比度目标
  465. /// </summary>
  466. /// <returns>true:float or false:NaN</returns>
  467. public float GetAutoContrast()
  468. {
  469. float ret = 0;
  470. if (ReadParams(AP_AUTO_CONTRAST, ref ret))
  471. {
  472. return ret;
  473. }
  474. else
  475. {
  476. return float.NaN;
  477. }
  478. }
  479. /// <summary>
  480. /// 设置对比度目标
  481. /// </summary>
  482. /// <param name="set">对比度目标</param>
  483. /// <returns>true or false</returns>
  484. public Boolean SetAutoContrast(float set)
  485. {
  486. return WriteParams(AP_AUTO_CONTRAST, set);
  487. }
  488. #endregion
  489. #region 消像散
  490. /// <summary>
  491. /// 读取消像散X
  492. /// </summary>
  493. /// <returns>true:float or false:NaN</returns>
  494. public float GetAstigmatismX()
  495. {
  496. float ret = 0;
  497. if (ReadParams(AP_STIG_X, ref ret))
  498. {
  499. return ret;
  500. }
  501. else
  502. {
  503. return float.NaN;
  504. }
  505. }
  506. /// <summary>
  507. /// 读取消像散Y
  508. /// </summary>
  509. /// <returns>true:float or false:NaN</returns>
  510. public float GetAstigmatismY()
  511. {
  512. float ret = 0;
  513. if (ReadParams(AP_STIG_Y, ref ret))
  514. {
  515. return ret;
  516. }
  517. else
  518. {
  519. return float.NaN;
  520. }
  521. }
  522. /// <summary>
  523. /// 设置消像散X
  524. /// </summary>
  525. /// <param name="set">对比度</param>
  526. /// <returns>true or false</returns>
  527. public Boolean SetAstigmatismX(float set)
  528. {
  529. return WriteParams(AP_STIG_X, set);
  530. }
  531. /// <summary>
  532. /// 设置消像散Y
  533. /// </summary>
  534. /// <param name="set">对比度</param>
  535. /// <returns>true or false</returns>
  536. public Boolean SetAstigmatismY(float set)
  537. {
  538. return WriteParams(AP_STIG_Y, set);
  539. }
  540. #endregion
  541. #region 角度补偿
  542. /// <summary>
  543. /// 读取角度补偿
  544. /// </summary>
  545. /// <returns>true:float or false:NaN</returns>
  546. public float GetTiltAngle()
  547. {
  548. float ret = 0;
  549. if (ReadParams(AP_TILT_ANGLE, ref ret))
  550. {
  551. return ret;
  552. }
  553. else
  554. {
  555. return float.NaN;
  556. }
  557. }
  558. /// <summary>
  559. /// 设置角度补偿
  560. /// </summary>
  561. /// <param name="set">角度补偿</param>
  562. /// <returns>true or false</returns>
  563. public Boolean SetTiltAngle(float set)
  564. {
  565. Boolean ret = false;
  566. ret = WriteDataParams(DP_TILT_CORRECTION, 1);
  567. ret = WriteParams(AP_TILT_ANGLE, set);
  568. ret = WriteDataParams(DP_TILT_CORRECTION, 0);
  569. return ret;
  570. }
  571. #endregion
  572. #region 图像大小
  573. public int[] GetImageStore()
  574. {
  575. int[] i_ret = new int[2];
  576. float ret = 0;
  577. if (ReadParams(DP_IMAGE_STORE, ref ret))
  578. {
  579. switch(ret)
  580. {
  581. case 0:
  582. i_ret[0] = 1024;
  583. i_ret[1] = 768;
  584. break;
  585. case 1:
  586. i_ret[0] = 512;
  587. i_ret[1] = 384;
  588. break;
  589. case 2:
  590. i_ret[0] = 2048;
  591. i_ret[1] = 1536;
  592. break;
  593. case 3:
  594. i_ret[0] = 3072;
  595. i_ret[1] = 2304;
  596. break;
  597. case 4:
  598. i_ret[0] = 4096;
  599. i_ret[1] = 3072;
  600. break;
  601. case 5:
  602. i_ret[0] = 5120;
  603. i_ret[1] = 3840;
  604. break;
  605. case 6:
  606. i_ret[0] = 6144;
  607. i_ret[1] = 4608;
  608. break;
  609. case 7:
  610. i_ret[0] = 8192;
  611. i_ret[1] = 6144;
  612. break;
  613. case 8:
  614. i_ret[0] = 12288;
  615. i_ret[1] = 9216;
  616. break;
  617. case 9:
  618. i_ret[0] = 16384;
  619. i_ret[1] = 12288;
  620. break;
  621. case 10:
  622. i_ret[0] = 24576;
  623. i_ret[1] = 18432;
  624. break;
  625. case 11:
  626. i_ret[0] = 32768;
  627. i_ret[1] = 24576;
  628. break;
  629. default:
  630. i_ret[0] = 0;
  631. i_ret[1] = 0;
  632. break;
  633. }
  634. }
  635. else
  636. {
  637. i_ret[0] = 0;
  638. i_ret[1] = 0;
  639. }
  640. return i_ret;
  641. }
  642. public Boolean SetImageStore(float set)
  643. {
  644. return WriteDataParams("DP_IMAGE_STORE", set);
  645. }
  646. #endregion
  647. #region 抓取图像
  648. /// <summary>
  649. /// 抓取图像
  650. /// </summary>
  651. /// <returns>true:float or false:NaN</returns>
  652. public Boolean GrabImage(String filename, short xoff,short yoff, short width,short height,short type)
  653. {
  654. if (m_bInitialised)
  655. {
  656. long lrt = CZEMApi.Grab(xoff, yoff, width, height, type, filename);
  657. if (lrt != 0)
  658. {
  659. return false;
  660. }
  661. else
  662. {
  663. ImageFrozen();
  664. return true;
  665. }
  666. }
  667. else
  668. {
  669. return false;
  670. }
  671. }
  672. #endregion
  673. #region 图像解冻
  674. public Boolean ImageFrozen()
  675. {
  676. return WriteDataParams(DP_FROZEN, (float)1);
  677. }
  678. public Boolean ImageLive()
  679. {
  680. return WriteDataParams(DP_FROZEN, (float)0);
  681. }
  682. #endregion
  683. #region 图像类型切换
  684. public Boolean DetectorType(float set)
  685. {
  686. return WriteDataParams(DP_DETECTOR_TYPE, set);
  687. }
  688. #endregion
  689. #region 电子束移动接口
  690. /// <summary>
  691. /// 获取电子束移动接口X
  692. /// </summary>
  693. /// <returns>true:float or false:NaN</returns>
  694. public float GetBeamShiftX()
  695. {
  696. float ret = 0;
  697. if (ReadParams(AP_BEAMSHIFT_X, ref ret))
  698. {
  699. return ret;
  700. }
  701. else
  702. {
  703. return float.NaN;
  704. }
  705. }
  706. /// <summary>
  707. /// 获取电子束移动接口Y
  708. /// </summary>
  709. /// <returns>true:float or false:NaN</returns>
  710. public float GetBeamShiftY()
  711. {
  712. float ret = 0;
  713. if (ReadParams(AP_BEAMSHIFT_Y, ref ret))
  714. {
  715. return ret;
  716. }
  717. else
  718. {
  719. return float.NaN;
  720. }
  721. }
  722. /// <summary>
  723. /// 设置电子束移动接口X
  724. /// </summary>
  725. /// <param name="set">X坐标</param>
  726. /// <returns>true or false</returns>
  727. public Boolean SetBeamShiftX(float set)
  728. {
  729. return WriteParams(AP_BEAMSHIFT_X, set);
  730. }
  731. /// <summary>
  732. /// 设置电子束移动接口Y
  733. /// </summary>
  734. /// <param name="set">X坐标</param>
  735. /// <returns>true or false</returns>
  736. public Boolean SetBeamShiftY(float set)
  737. {
  738. return WriteParams(AP_BEAMSHIFT_Y, set);
  739. }
  740. #endregion
  741. #region 样品台移动接口
  742. /// <summary>
  743. /// 返回样品台坐标数组
  744. /// </summary>
  745. /// <returns>Lenght=6</returns>
  746. public float[] GetStagePosition()
  747. {
  748. object retx = new VariantWrapper((float)0.0f);
  749. object rety = new VariantWrapper((float)0.0f);
  750. object retz = new VariantWrapper((float)0.0f);
  751. object rett = new VariantWrapper((float)0.0f);
  752. object retr = new VariantWrapper((float)0.0f);
  753. object retm = new VariantWrapper((float)0.0f);
  754. float[] ret = new float[6];
  755. if (m_bInitialised)
  756. {
  757. CZEMApi.GetStagePosition(ref retx, ref rety, ref retz, ref rett, ref retr, ref retm);
  758. ret[0] = Convert.ToSingle(retx);
  759. ret[1] = Convert.ToSingle(rety);
  760. ret[2] = Convert.ToSingle(retz);
  761. ret[3] = Convert.ToSingle(rett);
  762. ret[4] = Convert.ToSingle(retr);
  763. ret[5] = Convert.ToSingle(retm);
  764. }
  765. else
  766. {
  767. ret[0] = float.NaN;
  768. ret[1] = float.NaN;
  769. ret[2] = float.NaN;
  770. ret[3] = float.NaN;
  771. ret[4] = float.NaN;
  772. ret[5] = float.NaN;
  773. }
  774. return ret;
  775. }
  776. /// <summary>
  777. /// 设置样品台坐标数组
  778. /// </summary>
  779. /// <returns>Lenght=6</returns>
  780. private Boolean SetStagePosition(float[] set)
  781. {
  782. if (m_bInitialised)
  783. {
  784. long lrt = CZEMApi.MoveStage(set[0], set[1], set[2], set[3], set[4], set[5]);
  785. if(lrt==0)
  786. {
  787. return true;
  788. }
  789. else
  790. {
  791. return false;
  792. }
  793. }
  794. else
  795. {
  796. return false;
  797. }
  798. }
  799. /// <summary>
  800. /// 样品台位置 X轴
  801. /// </summary>
  802. /// <returns>true:float or false:NaN</returns>
  803. public float GetStageAtX()
  804. {
  805. float ret = 0;
  806. if (ReadParams(AP_STAGE_AT_X, ref ret))
  807. {
  808. return ret;
  809. }
  810. else
  811. {
  812. return float.NaN;
  813. }
  814. }
  815. /// <summary>
  816. /// 样品台位置 Y轴
  817. /// </summary>
  818. /// <returns>true:float or false:NaN</returns>
  819. public float GetStageAtY()
  820. {
  821. float ret = 0;
  822. if (ReadParams(AP_STAGE_AT_Y, ref ret))
  823. {
  824. return ret;
  825. }
  826. else
  827. {
  828. return float.NaN;
  829. }
  830. }
  831. /// <summary>
  832. /// 样品台位置 Z轴
  833. /// </summary>
  834. /// <returns>true:float or false:NaN</returns>
  835. public float GetStageAtZ()
  836. {
  837. float ret = 0;
  838. if (ReadParams(AP_STAGE_AT_Z, ref ret))
  839. {
  840. return ret;
  841. }
  842. else
  843. {
  844. return float.NaN;
  845. }
  846. }
  847. /// <summary>
  848. /// 样品台位置 T轴
  849. /// </summary>
  850. /// <returns>true:float or false:NaN</returns>
  851. public float GetStageAtT()
  852. {
  853. float ret = 0;
  854. if (ReadParams(AP_STAGE_AT_T, ref ret))
  855. {
  856. return ret;
  857. }
  858. else
  859. {
  860. return float.NaN;
  861. }
  862. }
  863. /// <summary>
  864. /// 样品台位置 R轴
  865. /// </summary>
  866. /// <returns>true:float or false:NaN</returns>
  867. public float GetStageAtR()
  868. {
  869. float ret = 0;
  870. if (ReadParams(AP_STAGE_AT_R, ref ret))
  871. {
  872. return ret;
  873. }
  874. else
  875. {
  876. return float.NaN;
  877. }
  878. }
  879. /// <summary>
  880. /// 样品台位置 M轴
  881. /// </summary>
  882. /// <returns>true:float or false:NaN</returns>
  883. public float GetStageAtM()
  884. {
  885. float ret = 0;
  886. if (ReadParams(AP_STAGE_AT_M, ref ret))
  887. {
  888. return ret;
  889. }
  890. else
  891. {
  892. return float.NaN;
  893. }
  894. }
  895. /// <summary>
  896. /// 样品台位置 X轴
  897. /// </summary>
  898. /// <param name="set">X轴移动坐标</param>
  899. /// <returns></returns>
  900. public Boolean SetStageGotoX(float set)
  901. {
  902. return WriteParams(AP_STAGE_GOTO_X, set);
  903. }
  904. /// <summary>
  905. /// 样品台位置 Y轴
  906. /// </summary>
  907. /// <param name="set">Y轴移动坐标</param>
  908. /// <returns></returns>
  909. public Boolean SetStageGotoY(float set)
  910. {
  911. return WriteParams(AP_STAGE_GOTO_Y, set);
  912. }
  913. /// <summary>
  914. /// 样品台位置 Z轴
  915. /// </summary>
  916. /// <param name="set">Y轴移动坐标</param>
  917. /// <returns></returns>
  918. public Boolean SetStageGotoZ(float set)
  919. {
  920. return WriteParams(AP_STAGE_GOTO_Z, set);
  921. }
  922. /// <summary>
  923. /// 样品台位置 T轴
  924. /// </summary>
  925. /// <param name="set">Y轴移动坐标</param>
  926. /// <returns></returns>
  927. public Boolean SetStageGotoT(float set)
  928. {
  929. return WriteParams(AP_STAGE_GOTO_T, set);
  930. }
  931. /// <summary>
  932. /// 样品台位置 R轴
  933. /// </summary>
  934. /// <param name="set">Y轴移动坐标</param>
  935. /// <returns></returns>
  936. public Boolean SetStageGotoR(float set)
  937. {
  938. return WriteParams(AP_STAGE_GOTO_R, set);
  939. }
  940. /// <summary>
  941. /// 样品台位置 M轴
  942. /// </summary>
  943. /// <param name="set">M轴移动坐标</param>
  944. /// <returns></returns>
  945. public Boolean SetStageGotoM(float set)
  946. {
  947. return WriteParams(AP_STAGE_GOTO_M, set);
  948. }
  949. #endregion
  950. #region 移动样品台XY轴
  951. public Boolean MoveStageXY(float x,float y)
  952. {
  953. //先取范围
  954. object xMin = new VariantWrapper((float)0.0f);
  955. object xMax = new VariantWrapper((float)0.0f);
  956. long lrt = CZEMApi.GetLimits(AP_STAGE_GOTO_X, ref xMin, ref xMax);
  957. if (lrt != 0)
  958. {
  959. return false;
  960. }
  961. if (x > Convert.ToSingle(xMax) || x < Convert.ToSingle(xMin))
  962. {
  963. return false;
  964. }
  965. object yMin = new VariantWrapper((float)0.0f);
  966. object yMax = new VariantWrapper((float)0.0f);
  967. lrt = CZEMApi.GetLimits(AP_STAGE_GOTO_Y, ref yMin, ref yMax);
  968. if (lrt != 0)
  969. {
  970. return false;
  971. }
  972. if (y > Convert.ToSingle(yMax) || y < Convert.ToSingle(yMin))
  973. {
  974. return false;
  975. }
  976. float[] gsp = GetStagePosition();
  977. gsp[0] = x;
  978. gsp[1] = y;
  979. return SetStagePosition(gsp);
  980. }
  981. #endregion
  982. #region 样品台急停
  983. public Boolean CmdStageAbort()
  984. {
  985. return ExecuteCmd(CMD_STAGE_ABORT);
  986. }
  987. #endregion
  988. #region Scan Rotate角度接口
  989. /// <summary>
  990. /// 获取Scan Rotate角度接口
  991. /// </summary>
  992. /// <returns>true:float or false:NaN</returns>
  993. public float GetScanRotation()
  994. {
  995. float ret = 0;
  996. if (ReadParams(AP_SCANROTATION, ref ret))
  997. {
  998. return ret;
  999. }
  1000. else
  1001. {
  1002. return float.NaN;
  1003. }
  1004. }
  1005. /// <summary>
  1006. /// 设置Scan Rotate角度接口
  1007. /// </summary>
  1008. /// <param name="set">角度补偿</param>
  1009. /// <returns>true or false</returns>
  1010. public Boolean SetScanRotation(float set)
  1011. {
  1012. Boolean ret = false;
  1013. ret = WriteDataParams(DP_SCAN_ROT, 1);
  1014. ret = WriteParams(AP_SCANROTATION, set);
  1015. ret = WriteDataParams(DP_SCAN_ROT, 0);
  1016. return ret;
  1017. }
  1018. #endregion
  1019. #region 像素读取PixelSize
  1020. /// <summary>
  1021. /// 获取Pixel Size 接口,只读
  1022. /// </summary>
  1023. /// <returns>true:float or false:NaN</returns>
  1024. public float GetPixelSize()
  1025. {
  1026. float ret = 0;
  1027. if (ReadParams(AP_PIXEL_SIZE, ref ret))
  1028. {
  1029. return ret;
  1030. }
  1031. else
  1032. {
  1033. return float.NaN;
  1034. }
  1035. }
  1036. #endregion
  1037. #region 电子束校正设置
  1038. /// <summary>
  1039. /// 读取电子束校正状态
  1040. /// </summary>
  1041. /// <returns></returns>
  1042. public float GetTiltCorrection()
  1043. {
  1044. float ret = 0;
  1045. if (ReadParams(DP_TILT_CORRECTION, ref ret))
  1046. {
  1047. return ret;
  1048. }
  1049. else
  1050. {
  1051. return float.NaN;
  1052. }
  1053. }
  1054. /// <summary>
  1055. /// 设置电子束校正状态
  1056. /// </summary>
  1057. /// <param name="set"></param>
  1058. /// <returns></returns>
  1059. public Boolean SetTiltCorrectionOff()
  1060. {
  1061. return WriteDataParams(DP_TILT_CORRECTION, (float)0);
  1062. }
  1063. public Boolean SetTiltCorrectionOn()
  1064. {
  1065. return WriteDataParams(DP_TILT_CORRECTION, (float)1);
  1066. }
  1067. #endregion
  1068. #region 开启电压
  1069. public Boolean CmdOpenVoltage()
  1070. {
  1071. return ExecuteCmd(CMD_BEAM_ON);
  1072. }
  1073. #endregion
  1074. #region 关闭电压
  1075. public Boolean CmdCloseVoltage()
  1076. {
  1077. return ExecuteCmd(CMD_EHT_OFF);
  1078. }
  1079. #endregion
  1080. #region 自动对焦1
  1081. public Boolean CmdAutoFocusCoarse()
  1082. {
  1083. return ExecuteCmd(CMD_AUTO_FOCUS_COARSE);
  1084. }
  1085. #endregion
  1086. #region 自动对焦2
  1087. public Boolean CmdAutoFocusFine()
  1088. {
  1089. return ExecuteCmd(CMD_AUTO_FOCUS_FINE);
  1090. }
  1091. #endregion
  1092. #region 自动消像散
  1093. public Boolean CmdAutoStig()
  1094. {
  1095. return ExecuteCmd(CMD_AUTO_STIG);
  1096. }
  1097. #endregion
  1098. #region 调用宏文件命令
  1099. public Boolean CMDMCFFilename(String filename)
  1100. {
  1101. String CMDMCF = MCF_FILENAME + filename;
  1102. return ExecuteCmd(CMDMCF);
  1103. }
  1104. #endregion
  1105. #region 读取样品台状态
  1106. public float GetStageIs()
  1107. {
  1108. float ret = 0;
  1109. if (ReadParams(DP_STAGE_IS, ref ret))
  1110. {
  1111. return ret;
  1112. }
  1113. else
  1114. {
  1115. return float.NaN;
  1116. }
  1117. }
  1118. #endregion
  1119. #region 读取自动函数的状态
  1120. public float GetAutoFunction()
  1121. {
  1122. float ret = 0;
  1123. if (ReadParams(DP_AUTO_FUNCTION, ref ret))
  1124. {
  1125. return ret;
  1126. }
  1127. else
  1128. {
  1129. return float.NaN;
  1130. }
  1131. }
  1132. #endregion
  1133. public void InsertPT()
  1134. {
  1135. }
  1136. //PT针退出
  1137. public void OutputPT()
  1138. {
  1139. }
  1140. }
  1141. }