SmartSEM.cs 32 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890891892893894895896897898899900901902903904905906907908909910911912913914915916917918919920921922923924925926927928929930931932933934935936937938939940941942943944945946947948949950951952953954955956957958959960961962963964965966967968969970971972973974975976977978979980981982983984985986987988989990991992993994995996997998999100010011002100310041005100610071008100910101011101210131014101510161017101810191020102110221023102410251026102710281029103010311032103310341035103610371038103910401041104210431044104510461047104810491050105110521053105410551056105710581059106010611062106310641065106610671068106910701071107210731074107510761077107810791080108110821083108410851086108710881089109010911092109310941095109610971098109911001101110211031104110511061107110811091110111111121113111411151116111711181119112011211122112311241125112611271128112911301131113211331134113511361137113811391140114111421143114411451146114711481149115011511152115311541155115611571158115911601161116211631164116511661167116811691170117111721173117411751176117711781179118011811182118311841185118611871188118911901191119211931194119511961197119811991200120112021203120412051206120712081209
  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 varMin = new VariantWrapper((float)0.0f);
  955. object varMax = new VariantWrapper((float)0.0f);
  956. long lrt = CZEMApi.GetLimits(AP_STAGE_GOTO_X, ref varMin, ref varMax);
  957. if (lrt != 0)
  958. {
  959. return false;
  960. }
  961. if (x > Convert.ToSingle(varMax) || x < Convert.ToSingle(varMin))
  962. {
  963. return false;
  964. }
  965. lrt = CZEMApi.GetLimits(AP_STAGE_GOTO_Y, ref varMin, ref varMax);
  966. if (lrt != 0)
  967. {
  968. return false;
  969. }
  970. if (y > Convert.ToSingle(varMax) || y < Convert.ToSingle(varMin))
  971. {
  972. return false;
  973. }
  974. float[] gsp = GetStagePosition();
  975. gsp[0] = x;
  976. gsp[1] = y;
  977. return SetStagePosition(gsp);
  978. }
  979. #endregion
  980. #region 样品台急停
  981. public Boolean CmdStageAbort()
  982. {
  983. return ExecuteCmd(CMD_STAGE_ABORT);
  984. }
  985. #endregion
  986. #region Scan Rotate角度接口
  987. /// <summary>
  988. /// 获取Scan Rotate角度接口
  989. /// </summary>
  990. /// <returns>true:float or false:NaN</returns>
  991. public float GetScanRotation()
  992. {
  993. float ret = 0;
  994. if (ReadParams(AP_SCANROTATION, ref ret))
  995. {
  996. return ret;
  997. }
  998. else
  999. {
  1000. return float.NaN;
  1001. }
  1002. }
  1003. /// <summary>
  1004. /// 设置Scan Rotate角度接口
  1005. /// </summary>
  1006. /// <param name="set">角度补偿</param>
  1007. /// <returns>true or false</returns>
  1008. public Boolean SetScanRotation(float set)
  1009. {
  1010. Boolean ret = false;
  1011. ret = WriteDataParams(DP_SCAN_ROT, 1);
  1012. ret = WriteParams(AP_SCANROTATION, set);
  1013. ret = WriteDataParams(DP_SCAN_ROT, 0);
  1014. return ret;
  1015. }
  1016. #endregion
  1017. #region 像素读取PixelSize
  1018. /// <summary>
  1019. /// 获取Pixel Size 接口,只读
  1020. /// </summary>
  1021. /// <returns>true:float or false:NaN</returns>
  1022. public float GetPixelSize()
  1023. {
  1024. float ret = 0;
  1025. if (ReadParams(AP_PIXEL_SIZE, ref ret))
  1026. {
  1027. return ret;
  1028. }
  1029. else
  1030. {
  1031. return float.NaN;
  1032. }
  1033. }
  1034. #endregion
  1035. #region 电子束校正设置
  1036. /// <summary>
  1037. /// 读取电子束校正状态
  1038. /// </summary>
  1039. /// <returns></returns>
  1040. public float GetTiltCorrection()
  1041. {
  1042. float ret = 0;
  1043. if (ReadParams(DP_TILT_CORRECTION, ref ret))
  1044. {
  1045. return ret;
  1046. }
  1047. else
  1048. {
  1049. return float.NaN;
  1050. }
  1051. }
  1052. /// <summary>
  1053. /// 设置电子束校正状态
  1054. /// </summary>
  1055. /// <param name="set"></param>
  1056. /// <returns></returns>
  1057. public Boolean SetTiltCorrectionOff()
  1058. {
  1059. return WriteDataParams(DP_TILT_CORRECTION, (float)0);
  1060. }
  1061. public Boolean SetTiltCorrectionOn()
  1062. {
  1063. return WriteDataParams(DP_TILT_CORRECTION, (float)1);
  1064. }
  1065. #endregion
  1066. #region 开启电压
  1067. public Boolean CmdOpenVoltage()
  1068. {
  1069. return ExecuteCmd(CMD_BEAM_ON);
  1070. }
  1071. #endregion
  1072. #region 关闭电压
  1073. public Boolean CmdCloseVoltage()
  1074. {
  1075. return ExecuteCmd(CMD_EHT_OFF);
  1076. }
  1077. #endregion
  1078. #region 自动对焦1
  1079. public Boolean CmdAutoFocusCoarse()
  1080. {
  1081. return ExecuteCmd(CMD_AUTO_FOCUS_COARSE);
  1082. }
  1083. #endregion
  1084. #region 自动对焦2
  1085. public Boolean CmdAutoFocusFine()
  1086. {
  1087. return ExecuteCmd(CMD_AUTO_FOCUS_FINE);
  1088. }
  1089. #endregion
  1090. #region 自动消像散
  1091. public Boolean CmdAutoStig()
  1092. {
  1093. return ExecuteCmd(CMD_AUTO_STIG);
  1094. }
  1095. #endregion
  1096. #region 调用宏文件命令
  1097. public Boolean CMDMCFFilename(String filename)
  1098. {
  1099. String CMDMCF = MCF_FILENAME + filename;
  1100. return ExecuteCmd(CMDMCF);
  1101. }
  1102. #endregion
  1103. #region 读取样品台状态
  1104. public float GetStageIs()
  1105. {
  1106. float ret = 0;
  1107. if (ReadParams(DP_STAGE_IS, ref ret))
  1108. {
  1109. return ret;
  1110. }
  1111. else
  1112. {
  1113. return float.NaN;
  1114. }
  1115. }
  1116. #endregion
  1117. #region 读取自动函数的状态
  1118. public float GetAutoFunction()
  1119. {
  1120. float ret = 0;
  1121. if (ReadParams(DP_AUTO_FUNCTION, ref ret))
  1122. {
  1123. return ret;
  1124. }
  1125. else
  1126. {
  1127. return float.NaN;
  1128. }
  1129. }
  1130. #endregion
  1131. }
  1132. }