SmartSEM.cs 43 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495969798991001011021031041051061071081091101111121131141151161171181191201211221231241251261271281291301311321331341351361371381391401411421431441451461471481491501511521531541551561571581591601611621631641651661671681691701711721731741751761771781791801811821831841851861871881891901911921931941951961971981992002012022032042052062072082092102112122132142152162172182192202212222232242252262272282292302312322332342352362372382392402412422432442452462472482492502512522532542552562572582592602612622632642652662672682692702712722732742752762772782792802812822832842852862872882892902912922932942952962972982993003013023033043053063073083093103113123133143153163173183193203213223233243253263273283293303313323333343353363373383393403413423433443453463473483493503513523533543553563573583593603613623633643653663673683693703713723733743753763773783793803813823833843853863873883893903913923933943953963973983994004014024034044054064074084094104114124134144154164174184194204214224234244254264274284294304314324334344354364374384394404414424434444454464474484494504514524534544554564574584594604614624634644654664674684694704714724734744754764774784794804814824834844854864874884894904914924934944954964974984995005015025035045055065075085095105115125135145155165175185195205215225235245255265275285295305315325335345355365375385395405415425435445455465475485495505515525535545555565575585595605615625635645655665675685695705715725735745755765775785795805815825835845855865875885895905915925935945955965975985996006016026036046056066076086096106116126136146156166176186196206216226236246256266276286296306316326336346356366376386396406416426436446456466476486496506516526536546556566576586596606616626636646656666676686696706716726736746756766776786796806816826836846856866876886896906916926936946956966976986997007017027037047057067077087097107117127137147157167177187197207217227237247257267277287297307317327337347357367377387397407417427437447457467477487497507517527537547557567577587597607617627637647657667677687697707717727737747757767777787797807817827837847857867877887897907917927937947957967977987998008018028038048058068078088098108118128138148158168178188198208218228238248258268278288298308318328338348358368378388398408418428438448458468478488498508518528538548558568578588598608618628638648658668678688698708718728738748758768778788798808818828838848858868878888898908918928938948958968978988999009019029039049059069079089099109119129139149159169179189199209219229239249259269279289299309319329339349359369379389399409419429439449459469479489499509519529539549559569579589599609619629639649659669679689699709719729739749759769779789799809819829839849859869879889899909919929939949959969979989991000100110021003100410051006100710081009101010111012101310141015101610171018101910201021102210231024102510261027102810291030103110321033103410351036103710381039104010411042104310441045104610471048104910501051105210531054105510561057105810591060106110621063106410651066106710681069107010711072107310741075107610771078107910801081108210831084108510861087108810891090109110921093109410951096109710981099110011011102110311041105110611071108110911101111111211131114111511161117111811191120112111221123112411251126112711281129113011311132113311341135113611371138113911401141114211431144114511461147114811491150115111521153115411551156115711581159116011611162116311641165116611671168116911701171117211731174117511761177117811791180118111821183118411851186118711881189119011911192119311941195119611971198119912001201120212031204120512061207120812091210121112121213121412151216121712181219122012211222122312241225122612271228122912301231123212331234123512361237123812391240124112421243124412451246124712481249125012511252125312541255125612571258125912601261126212631264126512661267126812691270127112721273127412751276127712781279128012811282128312841285128612871288128912901291129212931294129512961297129812991300130113021303130413051306130713081309131013111312131313141315131613171318131913201321132213231324132513261327132813291330133113321333133413351336133713381339134013411342134313441345134613471348134913501351135213531354135513561357135813591360136113621363136413651366136713681369137013711372137313741375137613771378137913801381138213831384138513861387138813891390139113921393139413951396139713981399140014011402140314041405140614071408140914101411141214131414141514161417141814191420142114221423142414251426142714281429143014311432143314341435143614371438143914401441144214431444144514461447144814491450145114521453145414551456145714581459146014611462146314641465146614671468146914701471147214731474147514761477147814791480148114821483148414851486148714881489149014911492149314941495149614971498149915001501150215031504150515061507150815091510151115121513151415151516151715181519152015211522152315241525152615271528152915301531153215331534153515361537153815391540154115421543154415451546154715481549155015511552155315541555155615571558155915601561156215631564156515661567156815691570157115721573157415751576157715781579158015811582158315841585158615871588
  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. using System.IO;
  13. namespace SmartSEMControl
  14. {
  15. //可能遇到的错误提示部分??在log加入之后添加
  16. class SmartSEM : ISEMControl
  17. {
  18. #region 固定参数
  19. private String ELYPATH= @"C:\ProgramData\Carl Zeiss\SmartFIB\API\Drop\";
  20. private String ELYFILENAME = "ApiLayout.ely";
  21. #endregion
  22. #region 模拟参数
  23. //放大缩小
  24. private String AP_MAG = "AP_MAG";
  25. //焦距
  26. private String AP_WD = "AP_WD";
  27. //亮度
  28. private String AP_BRIGHTNESS = "AP_BRIGHTNESS";
  29. //对比度
  30. private String AP_CONTRAST = "AP_CONTRAST";
  31. //亮度目标
  32. private String AP_AUTO_BRIGHT = "AP_AUTO_BRIGHT";
  33. //对比度目标
  34. private String AP_AUTO_CONTRAST = "AP_AUTO_CONTRAST";
  35. //消像散X轴
  36. private String AP_STIG_X = "AP_STIG_X";
  37. //消像散Y轴
  38. private String AP_STIG_Y = "AP_STIG_Y";
  39. //角度补偿
  40. private String AP_TILT_ANGLE = "AP_TILT_ANGLE";
  41. //SEM移动X
  42. private String AP_BEAMSHIFT_X = "AP_BEAMSHIFT_X";
  43. //SEM移动Y
  44. private String AP_BEAMSHIFT_Y = "AP_BEAMSHIFT_Y";
  45. //X轴移动到
  46. private String AP_STAGE_GOTO_X = "AP_STAGE_GOTO_X";
  47. //Y轴移动到
  48. private String AP_STAGE_GOTO_Y = "AP_STAGE_GOTO_Y";
  49. //Z轴移动到
  50. private String AP_STAGE_GOTO_Z = "AP_STAGE_GOTO_Z";
  51. //T轴移动到
  52. private String AP_STAGE_GOTO_T = "AP_STAGE_GOTO_T";
  53. //R轴移动到
  54. private String AP_STAGE_GOTO_R = "AP_STAGE_GOTO_R";
  55. //M轴移动到
  56. private String AP_STAGE_GOTO_M = "AP_STAGE_GOTO_M";
  57. //Scan Rotate角度
  58. private String AP_SCANROTATION = "AP_SCANROTATION";
  59. //像素大小
  60. private String AP_PIXEL_SIZE = "AP_PIXEL_SIZE";
  61. //X轴坐标
  62. private String AP_STAGE_AT_X = "AP_STAGE_AT_X";
  63. //Y轴坐标
  64. private String AP_STAGE_AT_Y = "AP_STAGE_AT_Y";
  65. //Z轴坐标
  66. private String AP_STAGE_AT_Z = "AP_STAGE_AT_Z";
  67. //T轴坐标
  68. private String AP_STAGE_AT_T = "AP_STAGE_AT_T";
  69. //R轴坐标
  70. private String AP_STAGE_AT_R = "AP_STAGE_AT_R";
  71. //M轴坐标
  72. private String AP_STAGE_AT_M = "AP_STAGE_AT_M";
  73. //FIB缩放
  74. private String AP_FIB_MAGNIFICATION = "AP_FIB_MAGNIFICATION";
  75. //FIB焦距
  76. private String AP_FIB_OBJECTIVE_POTENTIAL = "AP_FIB_OBJECTIVE_POTENTIAL";
  77. //FIB消像散X
  78. private String AP_FIB_STIGMATOR_X = "AP_FIB_STIGMATOR_X";
  79. //FIB消像散Y
  80. private String AP_FIB_STIGMATOR_Y = "AP_FIB_STIGMATOR_Y";
  81. //FIB光束移动X
  82. private String AP_FIB_BEAM_SHIFT_X = "AP_FIB_BEAM_SHIFT_X";
  83. //FIB光束移动Y
  84. private String AP_FIB_BEAM_SHIFT_Y = "AP_FIB_BEAM_SHIFT_Y";
  85. #endregion
  86. #region 数字参数
  87. //Scan Rotate开关
  88. private String DP_SCAN_ROT = "DP_SCAN_ROT";
  89. //取消电子束校正
  90. private String DP_TILT_CORRECTION = "DP_TILT_CORRECTION";
  91. //自动亮度对比度
  92. private String DP_AUTO_VIDEO = "DP_AUTO_VIDEO";
  93. //图像解冻
  94. private String DP_FROZEN = "DP_FROZEN";
  95. //图像类型切换
  96. private String DP_DETECTOR_TYPE = "DP_DETECTOR_TYPE";
  97. //图像大小
  98. private String DP_IMAGE_STORE = "DP_IMAGE_STORE";
  99. //样品台状态
  100. private String DP_STAGE_IS = "DP_STAGE_IS";
  101. //自动函数状态
  102. private String DP_AUTO_FUNCTION = "DP_AUTO_FUNCTION";
  103. //FIB模式
  104. private String DP_FIB_MODE = "DP_FIB_MODE";
  105. //FIB_IMAGING
  106. private String DP_FIB_IMAGING = "DP_FIB_IMAGING";
  107. //FIB状态
  108. private String DP_SMARTFIB_API_STATUS = "DP_SMARTFIB_API_STATUS";
  109. #endregion
  110. #region 命令
  111. //开启电压
  112. private String CMD_BEAM_ON = "CMD_BEAM_ON";
  113. //关闭电压
  114. private String CMD_EHT_OFF = "CMD_EHT_OFF";
  115. //自动对焦1
  116. private String CMD_AUTO_FOCUS_COARSE = "CMD_AUTO_FOCUS_COARSE";
  117. //自动对焦2
  118. private String CMD_AUTO_FOCUS_FINE = "CMD_AUTO_FOCUS_FINE";
  119. //自动消像散
  120. private String CMD_AUTO_STIG = "CMD_AUTO_STIG";
  121. //样品台急停
  122. private String CMD_STAGE_ABORT = "CMD_STAGE_ABORT";
  123. //FIB模式选择
  124. private String CMD_FIB_MODE_SEM = "CMD_FIB_MODE_SEM";
  125. private String CMD_FIB_MODE_FIB = "CMD_FIB_MODE_FIB";
  126. private String CMD_FIB_MODE_MILL = "CMD_FIB_MODE_MILL";
  127. private String CMD_FIB_MODE_SEM_FIB = "CMD_FIB_MODE_SEM_FIB";
  128. private String CMD_FIB_MODE_MILL_SEM = "CMD_FIB_MODE_MILL_SEM";
  129. private String CMD_FIB_MODE_EXT = "CMD_FIB_MODE_EXT";
  130. private String CMD_FIB_MODE_EXT_SEM = "CMD_FIB_MODE_EXT_SEM";
  131. private String CMD_FIB_MODE_ARGON_SEM = "CMD_FIB_MODE_ARGON_SEM";
  132. private String CMD_FIB_MODE_DRIFT_SEM = "CMD_FIB_MODE_DRIFT_SEM";
  133. private String CMD_FIB_MODE_DRIFT_FIB = "CMD_FIB_MODE_DRIFT_FIB";
  134. private String CMD_FIB_MODE_ARGON = "CMD_FIB_MODE_ARGON";
  135. //FIB加载.ely文件命令
  136. private String CMD_SMARTFIB_LOAD_ELY = "CMD_SMARTFIB_LOAD_ELY";
  137. #endregion
  138. #region 宏文件命令
  139. private String MCF_FILENAME = "MCF_";
  140. #endregion
  141. #region APILib
  142. private Api CZEMApi = new Api();
  143. private Boolean m_bInitialised = false;
  144. #endregion
  145. #region 构造函数
  146. public SmartSEM()
  147. {
  148. Init();
  149. }
  150. #endregion
  151. #region 设备初始化
  152. /// <summary>
  153. /// 设备初始化
  154. /// </summary>
  155. /// <returns>return:true or false</returns>
  156. public Boolean Init()
  157. {
  158. long lrt = 0;
  159. #if ROMOTE
  160. lrt = CZEMApi.InitialiseRemoting();
  161. #else
  162. lrt = CZEMApi.Initialise("");
  163. #endif
  164. if (lrt != 0)
  165. {
  166. m_bInitialised = false;
  167. return false;
  168. }
  169. else
  170. {
  171. m_bInitialised = true;
  172. return true;
  173. }
  174. }
  175. #endregion
  176. #region 设备远程初始化
  177. /// <summary>
  178. /// 设备远程初始化
  179. /// </summary>
  180. /// <returns>return:true or false</returns>
  181. public Boolean InitRemoting()
  182. {
  183. long lrt = CZEMApi.InitialiseRemoting();
  184. if (lrt != 0)
  185. {
  186. m_bInitialised = false;
  187. return false;
  188. }
  189. else
  190. {
  191. m_bInitialised = true;
  192. return true;
  193. }
  194. }
  195. #endregion
  196. #region 连接状态
  197. public Boolean ConnectStatus()
  198. {
  199. return m_bInitialised;
  200. }
  201. #endregion
  202. #region 关闭设备
  203. /// <summary>
  204. /// 关闭设备
  205. /// </summary>
  206. /// <returns>true or false</returns>
  207. public Boolean Dispose()
  208. {
  209. if (m_bInitialised)
  210. {
  211. long lrt = CZEMApi.ClosingControl();
  212. if (lrt != 0)
  213. {
  214. return false;
  215. }
  216. else
  217. {
  218. m_bInitialised = false;
  219. return true;
  220. }
  221. }
  222. else
  223. {
  224. return false;
  225. }
  226. }
  227. #endregion
  228. #region 读参数函数
  229. private Boolean ReadParams(String str_param, ref float value)
  230. {
  231. if (m_bInitialised)
  232. {
  233. object varfloat = new VariantWrapper((float)0.0f);
  234. long lrt = CZEMApi.Get(str_param, ref varfloat);
  235. if (lrt != 0)
  236. {
  237. return false;
  238. }
  239. else
  240. {
  241. value = Convert.ToSingle(varfloat);
  242. return true;
  243. }
  244. }
  245. else
  246. {
  247. return false;
  248. }
  249. }
  250. #endregion
  251. #region 写模拟参数函数
  252. private Boolean WriteParams(String str_param, float value)
  253. {
  254. if (m_bInitialised)
  255. {
  256. //先取范围
  257. object varMin = new VariantWrapper((float)0.0f);
  258. object varMax = new VariantWrapper((float)0.0f);
  259. long lrt = CZEMApi.GetLimits(str_param, ref varMin, ref varMax);
  260. if (lrt != 0)
  261. {
  262. return false;
  263. }
  264. if (value <= Convert.ToSingle(varMax) && value >= Convert.ToSingle(varMin))
  265. {
  266. object varFloat = new VariantWrapper(value);
  267. lrt = CZEMApi.Set(str_param, ref varFloat);// set value
  268. if (lrt != 0)
  269. {
  270. return false;
  271. }
  272. return true;
  273. }
  274. else
  275. {
  276. return false;
  277. }
  278. }
  279. else
  280. {
  281. return false;
  282. }
  283. }
  284. #endregion
  285. #region 写数字参数函数
  286. private Boolean WriteDataParams(String str_param, float value)
  287. {
  288. if (m_bInitialised)
  289. {
  290. object varFloat = new VariantWrapper(value);
  291. long lrt = CZEMApi.Set(str_param, ref varFloat);// set value
  292. if (lrt != 0)
  293. {
  294. return false;
  295. }
  296. return true;
  297. }
  298. else
  299. {
  300. return false;
  301. }
  302. }
  303. #endregion
  304. #region 执行命令
  305. private Boolean ExecuteCmd(String cmd)
  306. {
  307. if (m_bInitialised)
  308. {
  309. long lrt = CZEMApi.Execute(cmd);// execute command
  310. if (lrt != 0)
  311. {
  312. return false;
  313. }
  314. else
  315. {
  316. return true;
  317. }
  318. }
  319. else
  320. {
  321. return false;
  322. }
  323. }
  324. #endregion
  325. #region SEM缩放
  326. /// <summary>
  327. /// 读取缩放倍数
  328. /// </summary>
  329. /// <returns>true:float or false:NaN</returns>
  330. public float GetMagnification()
  331. {
  332. float ret = 0;
  333. if(ReadParams(AP_MAG, ref ret))
  334. {
  335. return ret;
  336. }
  337. else
  338. {
  339. return float.NaN;
  340. }
  341. }
  342. /// <summary>
  343. /// 设置缩放倍数
  344. /// </summary>
  345. /// <param name="set">倍数</param>
  346. /// <returns>true or false</returns>
  347. public Boolean SetMagnification(float set)
  348. {
  349. return WriteParams(AP_MAG, set);
  350. }
  351. #endregion
  352. #region SEM焦距
  353. /// <summary>
  354. /// 读取工作距离
  355. /// </summary>
  356. /// <returns>true:float or false:NaN</returns>
  357. public float GetWorkingDistance()
  358. {
  359. float ret = 0;
  360. if (ReadParams(AP_WD, ref ret))
  361. {
  362. return ret;
  363. }
  364. else
  365. {
  366. return float.NaN;
  367. }
  368. }
  369. /// <summary>
  370. /// 设置焦距
  371. /// </summary>
  372. /// <param name="set">焦距</param>
  373. /// <returns>true or false</returns>
  374. public Boolean SetWorkingDistance(float set)
  375. {
  376. return WriteParams(AP_WD, set);
  377. }
  378. #endregion
  379. #region 亮度
  380. /// <summary>
  381. /// 读取亮度
  382. /// </summary>
  383. /// <returns>true:float or false:NaN</returns>
  384. public float GetBrightness()
  385. {
  386. float ret = 0;
  387. if (ReadParams(AP_BRIGHTNESS, ref ret))
  388. {
  389. return ret;
  390. }
  391. else
  392. {
  393. return float.NaN;
  394. }
  395. }
  396. /// <summary>
  397. /// 设置亮度
  398. /// </summary>
  399. /// <param name="set">亮度</param>
  400. /// <returns>true or false</returns>
  401. public Boolean SetBrightness(float set)
  402. {
  403. return WriteParams(AP_BRIGHTNESS, set);
  404. }
  405. #endregion
  406. #region 对比度
  407. /// <summary>
  408. /// 读取对比度
  409. /// </summary>
  410. /// <returns>true:float or false:NaN</returns>
  411. public float GetContrast()
  412. {
  413. float ret = 0;
  414. if (ReadParams(AP_CONTRAST, ref ret))
  415. {
  416. return ret;
  417. }
  418. else
  419. {
  420. return float.NaN;
  421. }
  422. }
  423. /// <summary>
  424. /// 设置对比度
  425. /// </summary>
  426. /// <param name="set">对比度</param>
  427. /// <returns>true or false</returns>
  428. public Boolean SetContrast(float set)
  429. {
  430. return WriteParams(AP_CONTRAST, set);
  431. }
  432. #endregion
  433. #region 自动亮度对比度
  434. /// <summary>
  435. /// 读取自动亮度对比度状态
  436. /// </summary>
  437. /// <returns>true:float or false:NaN</returns>
  438. public float GetAutoVideo()
  439. {
  440. float ret = 0;
  441. if (ReadParams(DP_AUTO_VIDEO, ref ret))
  442. {
  443. return ret;
  444. }
  445. else
  446. {
  447. return float.NaN;
  448. }
  449. }
  450. /// <summary>
  451. /// 设置自动亮度对比度状态
  452. /// </summary>
  453. /// <param name="set">0:off;1:B(亮度);2:C(对比度);3:BC</param>
  454. /// <returns>true or false</returns>
  455. public Boolean SetAutoVideoOff()
  456. {
  457. return WriteDataParams(DP_AUTO_VIDEO, (float)0);
  458. }
  459. public Boolean SetAutoVideoBrightness()
  460. {
  461. return WriteDataParams(DP_AUTO_VIDEO, (float)1);
  462. }
  463. public Boolean SetAutoVideoContrast()
  464. {
  465. return WriteDataParams(DP_AUTO_VIDEO, (float)2);
  466. }
  467. public Boolean SetAutoVideoBrightnessAndContrast()
  468. {
  469. return WriteDataParams(DP_AUTO_VIDEO, (float)3);
  470. }
  471. #endregion
  472. #region 亮度目标
  473. /// <summary>
  474. /// 读取亮度目标
  475. /// </summary>
  476. /// <returns>true:float or false:NaN</returns>
  477. public float GetAutoBright()
  478. {
  479. float ret = 0;
  480. if (ReadParams(AP_AUTO_BRIGHT, ref ret))
  481. {
  482. return ret;
  483. }
  484. else
  485. {
  486. return float.NaN;
  487. }
  488. }
  489. /// <summary>
  490. /// 设置亮度目标
  491. /// </summary>
  492. /// <param name="set">亮度</param>
  493. /// <returns>true or false</returns>
  494. public Boolean SetAutoBright(float set)
  495. {
  496. return WriteParams(AP_AUTO_BRIGHT, set);
  497. }
  498. #endregion
  499. #region 对比度目标
  500. /// <summary>
  501. /// 读取对比度目标
  502. /// </summary>
  503. /// <returns>true:float or false:NaN</returns>
  504. public float GetAutoContrast()
  505. {
  506. float ret = 0;
  507. if (ReadParams(AP_AUTO_CONTRAST, ref ret))
  508. {
  509. return ret;
  510. }
  511. else
  512. {
  513. return float.NaN;
  514. }
  515. }
  516. /// <summary>
  517. /// 设置对比度目标
  518. /// </summary>
  519. /// <param name="set">对比度目标</param>
  520. /// <returns>true or false</returns>
  521. public Boolean SetAutoContrast(float set)
  522. {
  523. return WriteParams(AP_AUTO_CONTRAST, set);
  524. }
  525. #endregion
  526. #region SEM消像散
  527. /// <summary>
  528. /// 读取消像散X
  529. /// </summary>
  530. /// <returns>true:float or false:NaN</returns>
  531. public float GetAstigmatismX()
  532. {
  533. float ret = 0;
  534. if (ReadParams(AP_STIG_X, ref ret))
  535. {
  536. return ret;
  537. }
  538. else
  539. {
  540. return float.NaN;
  541. }
  542. }
  543. /// <summary>
  544. /// 读取消像散Y
  545. /// </summary>
  546. /// <returns>true:float or false:NaN</returns>
  547. public float GetAstigmatismY()
  548. {
  549. float ret = 0;
  550. if (ReadParams(AP_STIG_Y, ref ret))
  551. {
  552. return ret;
  553. }
  554. else
  555. {
  556. return float.NaN;
  557. }
  558. }
  559. /// <summary>
  560. /// 设置消像散X
  561. /// </summary>
  562. /// <param name="set">对比度</param>
  563. /// <returns>true or false</returns>
  564. public Boolean SetAstigmatismX(float set)
  565. {
  566. return WriteParams(AP_STIG_X, set);
  567. }
  568. /// <summary>
  569. /// 设置消像散Y
  570. /// </summary>
  571. /// <param name="set">对比度</param>
  572. /// <returns>true or false</returns>
  573. public Boolean SetAstigmatismY(float set)
  574. {
  575. return WriteParams(AP_STIG_Y, set);
  576. }
  577. #endregion
  578. #region 角度补偿
  579. /// <summary>
  580. /// 读取角度补偿
  581. /// </summary>
  582. /// <returns>true:float or false:NaN</returns>
  583. public float GetTiltAngle()
  584. {
  585. float ret = 0;
  586. if (ReadParams(AP_TILT_ANGLE, ref ret))
  587. {
  588. return ret;
  589. }
  590. else
  591. {
  592. return float.NaN;
  593. }
  594. }
  595. /// <summary>
  596. /// 设置角度补偿
  597. /// </summary>
  598. /// <param name="set">角度补偿</param>
  599. /// <returns>true or false</returns>
  600. public Boolean SetTiltAngle(float set)
  601. {
  602. Boolean ret = false;
  603. ret = WriteDataParams(DP_TILT_CORRECTION, 1);
  604. ret = WriteParams(AP_TILT_ANGLE, set);
  605. ret = WriteDataParams(DP_TILT_CORRECTION, 0);
  606. return ret;
  607. }
  608. #endregion
  609. #region 图像大小
  610. public int[] GetImageStore()
  611. {
  612. int[] i_ret = new int[2];
  613. float ret = 0;
  614. if (ReadParams(DP_IMAGE_STORE, ref ret))
  615. {
  616. switch(ret)
  617. {
  618. case 0:
  619. i_ret[0] = 1024;
  620. i_ret[1] = 768;
  621. break;
  622. case 1:
  623. i_ret[0] = 512;
  624. i_ret[1] = 384;
  625. break;
  626. case 2:
  627. i_ret[0] = 2048;
  628. i_ret[1] = 1536;
  629. break;
  630. case 3:
  631. i_ret[0] = 3072;
  632. i_ret[1] = 2304;
  633. break;
  634. case 4:
  635. i_ret[0] = 4096;
  636. i_ret[1] = 3072;
  637. break;
  638. case 5:
  639. i_ret[0] = 5120;
  640. i_ret[1] = 3840;
  641. break;
  642. case 6:
  643. i_ret[0] = 6144;
  644. i_ret[1] = 4608;
  645. break;
  646. case 7:
  647. i_ret[0] = 8192;
  648. i_ret[1] = 6144;
  649. break;
  650. case 8:
  651. i_ret[0] = 12288;
  652. i_ret[1] = 9216;
  653. break;
  654. case 9:
  655. i_ret[0] = 16384;
  656. i_ret[1] = 12288;
  657. break;
  658. case 10:
  659. i_ret[0] = 24576;
  660. i_ret[1] = 18432;
  661. break;
  662. case 11:
  663. i_ret[0] = 32768;
  664. i_ret[1] = 24576;
  665. break;
  666. default:
  667. i_ret[0] = 0;
  668. i_ret[1] = 0;
  669. break;
  670. }
  671. }
  672. else
  673. {
  674. i_ret[0] = 0;
  675. i_ret[1] = 0;
  676. }
  677. return i_ret;
  678. }
  679. public Boolean SetImageStore(float set)
  680. {
  681. return WriteDataParams("DP_IMAGE_STORE", set);
  682. }
  683. #endregion
  684. #region 抓取图像
  685. /// <summary>
  686. /// 抓取图像
  687. /// </summary>
  688. /// <returns>true:float or false:NaN</returns>
  689. public Boolean GrabImage(String filename, short xoff,short yoff, short width,short height,short type)
  690. {
  691. if (m_bInitialised)
  692. {
  693. long lrt = CZEMApi.Grab(xoff, yoff, width, height, type, filename);
  694. if (lrt != 0)
  695. {
  696. return false;
  697. }
  698. else
  699. {
  700. ImageLive();
  701. return true;
  702. }
  703. }
  704. else
  705. {
  706. return false;
  707. }
  708. }
  709. #endregion
  710. #region 图像解冻
  711. public float GetImageFrozen()
  712. {
  713. float ret = 0;
  714. if (ReadParams(DP_FROZEN, ref ret))
  715. {
  716. return ret;
  717. }
  718. else
  719. {
  720. return float.NaN;
  721. }
  722. }
  723. public Boolean ImageFrozen()
  724. {
  725. return WriteDataParams(DP_FROZEN, (float)1);
  726. }
  727. public Boolean ImageLive()
  728. {
  729. return WriteDataParams(DP_FROZEN, (float)0);
  730. }
  731. #endregion
  732. #region 图像类型切换
  733. public Boolean DetectorType(float set)
  734. {
  735. return WriteDataParams(DP_DETECTOR_TYPE, set);
  736. }
  737. #endregion
  738. #region SEM电子束移动接口
  739. /// <summary>
  740. /// 获取电子束移动接口X
  741. /// </summary>
  742. /// <returns>true:float or false:NaN</returns>
  743. public float GetBeamShiftX()
  744. {
  745. float ret = 0;
  746. if (ReadParams(AP_BEAMSHIFT_X, ref ret))
  747. {
  748. return ret;
  749. }
  750. else
  751. {
  752. return float.NaN;
  753. }
  754. }
  755. /// <summary>
  756. /// 获取电子束移动接口Y
  757. /// </summary>
  758. /// <returns>true:float or false:NaN</returns>
  759. public float GetBeamShiftY()
  760. {
  761. float ret = 0;
  762. if (ReadParams(AP_BEAMSHIFT_Y, ref ret))
  763. {
  764. return ret;
  765. }
  766. else
  767. {
  768. return float.NaN;
  769. }
  770. }
  771. /// <summary>
  772. /// 设置电子束移动接口X
  773. /// </summary>
  774. /// <param name="set">X坐标</param>
  775. /// <returns>true or false</returns>
  776. public Boolean SetBeamShiftX(float set)
  777. {
  778. return WriteParams(AP_BEAMSHIFT_X, set);
  779. }
  780. /// <summary>
  781. /// 设置电子束移动接口Y
  782. /// </summary>
  783. /// <param name="set">X坐标</param>
  784. /// <returns>true or false</returns>
  785. public Boolean SetBeamShiftY(float set)
  786. {
  787. return WriteParams(AP_BEAMSHIFT_Y, set);
  788. }
  789. #endregion
  790. #region 样品台移动接口
  791. /// <summary>
  792. /// 返回样品台坐标数组
  793. /// </summary>
  794. /// <returns>Lenght=6</returns>
  795. public float[] GetStagePosition()
  796. {
  797. object retx = new VariantWrapper((float)0.0f);
  798. object rety = new VariantWrapper((float)0.0f);
  799. object retz = new VariantWrapper((float)0.0f);
  800. object rett = new VariantWrapper((float)0.0f);
  801. object retr = new VariantWrapper((float)0.0f);
  802. object retm = new VariantWrapper((float)0.0f);
  803. float[] ret = new float[6];
  804. if (m_bInitialised)
  805. {
  806. CZEMApi.GetStagePosition(ref retx, ref rety, ref retz, ref rett, ref retr, ref retm);
  807. ret[0] = Convert.ToSingle(retx);
  808. ret[1] = Convert.ToSingle(rety);
  809. ret[2] = Convert.ToSingle(retz);
  810. ret[3] = Convert.ToSingle(rett);
  811. ret[4] = Convert.ToSingle(retr);
  812. ret[5] = Convert.ToSingle(retm);
  813. }
  814. else
  815. {
  816. ret[0] = float.NaN;
  817. ret[1] = float.NaN;
  818. ret[2] = float.NaN;
  819. ret[3] = float.NaN;
  820. ret[4] = float.NaN;
  821. ret[5] = float.NaN;
  822. }
  823. return ret;
  824. }
  825. /// <summary>
  826. /// 设置样品台坐标数组
  827. /// </summary>
  828. /// <returns>Lenght=6</returns>
  829. private Boolean SetStagePosition(float[] set)
  830. {
  831. if (m_bInitialised)
  832. {
  833. long lrt = CZEMApi.MoveStage(set[0], set[1], set[2], set[3], set[4], set[5]);
  834. if(lrt==0)
  835. {
  836. return true;
  837. }
  838. else
  839. {
  840. return false;
  841. }
  842. }
  843. else
  844. {
  845. return false;
  846. }
  847. }
  848. /// <summary>
  849. /// 样品台位置 X轴
  850. /// </summary>
  851. /// <returns>true:float or false:NaN</returns>
  852. public float GetStageAtX()
  853. {
  854. float ret = 0;
  855. if (ReadParams(AP_STAGE_AT_X, ref ret))
  856. {
  857. return ret;
  858. }
  859. else
  860. {
  861. return float.NaN;
  862. }
  863. }
  864. /// <summary>
  865. /// 样品台位置 Y轴
  866. /// </summary>
  867. /// <returns>true:float or false:NaN</returns>
  868. public float GetStageAtY()
  869. {
  870. float ret = 0;
  871. if (ReadParams(AP_STAGE_AT_Y, ref ret))
  872. {
  873. return ret;
  874. }
  875. else
  876. {
  877. return float.NaN;
  878. }
  879. }
  880. /// <summary>
  881. /// 样品台位置 Z轴
  882. /// </summary>
  883. /// <returns>true:float or false:NaN</returns>
  884. public float GetStageAtZ()
  885. {
  886. float ret = 0;
  887. if (ReadParams(AP_STAGE_AT_Z, ref ret))
  888. {
  889. return ret;
  890. }
  891. else
  892. {
  893. return float.NaN;
  894. }
  895. }
  896. /// <summary>
  897. /// 样品台位置 T轴
  898. /// </summary>
  899. /// <returns>true:float or false:NaN</returns>
  900. public float GetStageAtT()
  901. {
  902. float ret = 0;
  903. if (ReadParams(AP_STAGE_AT_T, ref ret))
  904. {
  905. return ret;
  906. }
  907. else
  908. {
  909. return float.NaN;
  910. }
  911. }
  912. /// <summary>
  913. /// 样品台位置 R轴
  914. /// </summary>
  915. /// <returns>true:float or false:NaN</returns>
  916. public float GetStageAtR()
  917. {
  918. float ret = 0;
  919. if (ReadParams(AP_STAGE_AT_R, ref ret))
  920. {
  921. return ret;
  922. }
  923. else
  924. {
  925. return float.NaN;
  926. }
  927. }
  928. /// <summary>
  929. /// 样品台位置 M轴
  930. /// </summary>
  931. /// <returns>true:float or false:NaN</returns>
  932. public float GetStageAtM()
  933. {
  934. float ret = 0;
  935. if (ReadParams(AP_STAGE_AT_M, ref ret))
  936. {
  937. return ret;
  938. }
  939. else
  940. {
  941. return float.NaN;
  942. }
  943. }
  944. /// <summary>
  945. /// 样品台位置 X轴
  946. /// </summary>
  947. /// <param name="set">X轴移动坐标</param>
  948. /// <returns></returns>
  949. public Boolean SetStageGotoX(float set)
  950. {
  951. return WriteParams(AP_STAGE_GOTO_X, set);
  952. }
  953. /// <summary>
  954. /// 样品台位置 Y轴
  955. /// </summary>
  956. /// <param name="set">Y轴移动坐标</param>
  957. /// <returns></returns>
  958. public Boolean SetStageGotoY(float set)
  959. {
  960. return WriteParams(AP_STAGE_GOTO_Y, set);
  961. }
  962. /// <summary>
  963. /// 样品台位置 Z轴
  964. /// </summary>
  965. /// <param name="set">Y轴移动坐标</param>
  966. /// <returns></returns>
  967. public Boolean SetStageGotoZ(float set)
  968. {
  969. return WriteParams(AP_STAGE_GOTO_Z, set);
  970. }
  971. /// <summary>
  972. /// 样品台位置 T轴
  973. /// </summary>
  974. /// <param name="set">Y轴移动坐标</param>
  975. /// <returns></returns>
  976. public Boolean SetStageGotoT(float set)
  977. {
  978. return WriteParams(AP_STAGE_GOTO_T, set);
  979. }
  980. /// <summary>
  981. /// 样品台位置 R轴
  982. /// </summary>
  983. /// <param name="set">Y轴移动坐标</param>
  984. /// <returns></returns>
  985. public Boolean SetStageGotoR(float set)
  986. {
  987. return WriteParams(AP_STAGE_GOTO_R, set);
  988. }
  989. /// <summary>
  990. /// 样品台位置 M轴
  991. /// </summary>
  992. /// <param name="set">M轴移动坐标</param>
  993. /// <returns></returns>
  994. public Boolean SetStageGotoM(float set)
  995. {
  996. return WriteParams(AP_STAGE_GOTO_M, set);
  997. }
  998. #endregion
  999. #region 移动样品台XY轴
  1000. public Boolean MoveStageXY(float x,float y)
  1001. {
  1002. //先取范围
  1003. object xMin = new VariantWrapper((float)0.0f);
  1004. object xMax = new VariantWrapper((float)0.0f);
  1005. long lrt = CZEMApi.GetLimits(AP_STAGE_GOTO_X, ref xMin, ref xMax);
  1006. if (lrt != 0)
  1007. {
  1008. return false;
  1009. }
  1010. if (x > Convert.ToSingle(xMax) || x < Convert.ToSingle(xMin))
  1011. {
  1012. return false;
  1013. }
  1014. object yMin = new VariantWrapper((float)0.0f);
  1015. object yMax = new VariantWrapper((float)0.0f);
  1016. lrt = CZEMApi.GetLimits(AP_STAGE_GOTO_Y, ref yMin, ref yMax);
  1017. if (lrt != 0)
  1018. {
  1019. return false;
  1020. }
  1021. if (y > Convert.ToSingle(yMax) || y < Convert.ToSingle(yMin))
  1022. {
  1023. return false;
  1024. }
  1025. float[] gsp = GetStagePosition();
  1026. gsp[0] = x;
  1027. gsp[1] = y;
  1028. return SetStagePosition(gsp);
  1029. }
  1030. #endregion
  1031. #region 样品台急停
  1032. public Boolean CmdStageAbort()
  1033. {
  1034. return ExecuteCmd(CMD_STAGE_ABORT);
  1035. }
  1036. #endregion
  1037. #region Scan Rotate角度接口
  1038. /// <summary>
  1039. /// 获取Scan Rotate角度接口
  1040. /// </summary>
  1041. /// <returns>true:float or false:NaN</returns>
  1042. public float GetScanRotation()
  1043. {
  1044. float ret = 0;
  1045. if (ReadParams(AP_SCANROTATION, ref ret))
  1046. {
  1047. return ret;
  1048. }
  1049. else
  1050. {
  1051. return float.NaN;
  1052. }
  1053. }
  1054. /// <summary>
  1055. /// 设置Scan Rotate角度接口
  1056. /// </summary>
  1057. /// <param name="set">角度补偿</param>
  1058. /// <returns>true or false</returns>
  1059. public Boolean SetScanRotation(float set)
  1060. {
  1061. Boolean ret = false;
  1062. ret = WriteDataParams(DP_SCAN_ROT, 1);
  1063. ret = WriteParams(AP_SCANROTATION, set);
  1064. ret = WriteDataParams(DP_SCAN_ROT, 0);
  1065. return ret;
  1066. }
  1067. #endregion
  1068. #region 像素读取PixelSize
  1069. /// <summary>
  1070. /// 获取Pixel Size 接口,只读
  1071. /// </summary>
  1072. /// <returns>true:float or false:NaN</returns>
  1073. public float GetPixelSize()
  1074. {
  1075. float ret = 0;
  1076. if (ReadParams(AP_PIXEL_SIZE, ref ret))
  1077. {
  1078. return ret;
  1079. }
  1080. else
  1081. {
  1082. return float.NaN;
  1083. }
  1084. }
  1085. #endregion
  1086. #region 电子束校正设置
  1087. /// <summary>
  1088. /// 读取电子束校正状态
  1089. /// </summary>
  1090. /// <returns></returns>
  1091. public float GetTiltCorrection()
  1092. {
  1093. float ret = 0;
  1094. if (ReadParams(DP_TILT_CORRECTION, ref ret))
  1095. {
  1096. return ret;
  1097. }
  1098. else
  1099. {
  1100. return float.NaN;
  1101. }
  1102. }
  1103. /// <summary>
  1104. /// 设置电子束校正状态
  1105. /// </summary>
  1106. /// <param name="set"></param>
  1107. /// <returns></returns>
  1108. public Boolean SetTiltCorrectionOff()
  1109. {
  1110. return WriteDataParams(DP_TILT_CORRECTION, (float)0);
  1111. }
  1112. public Boolean SetTiltCorrectionOn()
  1113. {
  1114. return WriteDataParams(DP_TILT_CORRECTION, (float)1);
  1115. }
  1116. #endregion
  1117. #region 开启电压
  1118. public Boolean CmdOpenVoltage()
  1119. {
  1120. return ExecuteCmd(CMD_BEAM_ON);
  1121. }
  1122. #endregion
  1123. #region 关闭电压
  1124. public Boolean CmdCloseVoltage()
  1125. {
  1126. return ExecuteCmd(CMD_EHT_OFF);
  1127. }
  1128. #endregion
  1129. #region 自动对焦1
  1130. public Boolean CmdAutoFocusCoarse()
  1131. {
  1132. return ExecuteCmd(CMD_AUTO_FOCUS_COARSE);
  1133. }
  1134. #endregion
  1135. #region 自动对焦2
  1136. public Boolean CmdAutoFocusFine()
  1137. {
  1138. return ExecuteCmd(CMD_AUTO_FOCUS_FINE);
  1139. }
  1140. #endregion
  1141. #region 自动消像散
  1142. public Boolean CmdAutoStig()
  1143. {
  1144. return ExecuteCmd(CMD_AUTO_STIG);
  1145. }
  1146. #endregion
  1147. #region 调用宏文件命令
  1148. public Boolean CMDMCFFilename(String filename)
  1149. {
  1150. String CMDMCF = MCF_FILENAME + filename;
  1151. return ExecuteCmd(CMDMCF);
  1152. }
  1153. #endregion
  1154. #region 读取样品台状态
  1155. public float GetStageIs()
  1156. {
  1157. float ret = 0;
  1158. if (ReadParams(DP_STAGE_IS, ref ret))
  1159. {
  1160. return ret;
  1161. }
  1162. else
  1163. {
  1164. return float.NaN;
  1165. }
  1166. }
  1167. #endregion
  1168. #region 读取自动函数的状态
  1169. public float GetAutoFunction()
  1170. {
  1171. float ret = 0;
  1172. if (ReadParams(DP_AUTO_FUNCTION, ref ret))
  1173. {
  1174. return ret;
  1175. }
  1176. else
  1177. {
  1178. return float.NaN;
  1179. }
  1180. }
  1181. #endregion
  1182. #region FIB缩放
  1183. /// <summary>
  1184. /// 读取缩放倍数
  1185. /// </summary>
  1186. /// <returns>true:float or false:NaN</returns>
  1187. public float GetFIBMagnification()
  1188. {
  1189. float ret = 0;
  1190. if (ReadParams(AP_FIB_MAGNIFICATION, ref ret))
  1191. {
  1192. return ret;
  1193. }
  1194. else
  1195. {
  1196. return float.NaN;
  1197. }
  1198. }
  1199. /// <summary>
  1200. /// 设置缩放倍数
  1201. /// </summary>
  1202. /// <param name="set">倍数</param>
  1203. /// <returns>true or false</returns>
  1204. public Boolean SetFIBMagnification(float set)
  1205. {
  1206. return WriteParams(AP_FIB_MAGNIFICATION, set);
  1207. }
  1208. #endregion
  1209. #region FIB焦距
  1210. /// <summary>
  1211. /// 读取工作距离AP_FIB_OBJECTIVE_POTENTIAL
  1212. /// </summary>
  1213. /// <returns>true:float or false:NaN</returns>
  1214. public float GetFIBObjectivePotential()
  1215. {
  1216. float ret = 0;
  1217. if (ReadParams(AP_FIB_OBJECTIVE_POTENTIAL, ref ret))
  1218. {
  1219. return ret;
  1220. }
  1221. else
  1222. {
  1223. return float.NaN;
  1224. }
  1225. }
  1226. /// <summary>
  1227. /// 设置焦距
  1228. /// </summary>
  1229. /// <param name="set">焦距</param>
  1230. /// <returns>true or false</returns>
  1231. public Boolean SetFIBObjectivePotential(float set)
  1232. {
  1233. return WriteParams(AP_FIB_OBJECTIVE_POTENTIAL, set);
  1234. }
  1235. #endregion
  1236. #region FIB消像散
  1237. /// <summary>
  1238. /// 读取消像散X
  1239. /// </summary>
  1240. /// <returns>true:float or false:NaN</returns>
  1241. public float GetFIBAstigmatismX()
  1242. {
  1243. float ret = 0;
  1244. if (ReadParams(AP_FIB_STIGMATOR_X, ref ret))
  1245. {
  1246. return ret;
  1247. }
  1248. else
  1249. {
  1250. return float.NaN;
  1251. }
  1252. }
  1253. /// <summary>
  1254. /// 读取消像散Y
  1255. /// </summary>
  1256. /// <returns>true:float or false:NaN</returns>
  1257. public float GetFIBAstigmatismY()
  1258. {
  1259. float ret = 0;
  1260. if (ReadParams(AP_FIB_STIGMATOR_Y, ref ret))
  1261. {
  1262. return ret;
  1263. }
  1264. else
  1265. {
  1266. return float.NaN;
  1267. }
  1268. }
  1269. /// <summary>
  1270. /// 设置消像散X
  1271. /// </summary>
  1272. /// <param name="set">对比度</param>
  1273. /// <returns>true or false</returns>
  1274. public Boolean SetFIBAstigmatismX(float set)
  1275. {
  1276. return WriteParams(AP_FIB_STIGMATOR_X, set);
  1277. }
  1278. /// <summary>
  1279. /// 设置消像散Y
  1280. /// </summary>
  1281. /// <param name="set">对比度</param>
  1282. /// <returns>true or false</returns>
  1283. public Boolean SetFIBAstigmatismY(float set)
  1284. {
  1285. return WriteParams(AP_FIB_STIGMATOR_Y, set);
  1286. }
  1287. #endregion
  1288. #region FIB电子束移动接口
  1289. /// <summary>
  1290. /// 获取电子束移动接口X
  1291. /// </summary>
  1292. /// <returns>true:float or false:NaN</returns>
  1293. public float GetFIBBeamShiftX()
  1294. {
  1295. float ret = 0;
  1296. if (ReadParams(AP_FIB_BEAM_SHIFT_X, ref ret))
  1297. {
  1298. return ret;
  1299. }
  1300. else
  1301. {
  1302. return float.NaN;
  1303. }
  1304. }
  1305. /// <summary>
  1306. /// 获取电子束移动接口Y
  1307. /// </summary>
  1308. /// <returns>true:float or false:NaN</returns>
  1309. public float GetFIBBeamShiftY()
  1310. {
  1311. float ret = 0;
  1312. if (ReadParams(AP_FIB_BEAM_SHIFT_Y, ref ret))
  1313. {
  1314. return ret;
  1315. }
  1316. else
  1317. {
  1318. return float.NaN;
  1319. }
  1320. }
  1321. /// <summary>
  1322. /// 设置电子束移动接口X
  1323. /// </summary>
  1324. /// <param name="set">X坐标</param>
  1325. /// <returns>true or false</returns>
  1326. public Boolean SetFIBBeamShiftX(float set)
  1327. {
  1328. return WriteParams(AP_FIB_BEAM_SHIFT_X, set);
  1329. }
  1330. /// <summary>
  1331. /// 设置电子束移动接口Y
  1332. /// </summary>
  1333. /// <param name="set">X坐标</param>
  1334. /// <returns>true or false</returns>
  1335. public Boolean SetFIBBeamShiftY(float set)
  1336. {
  1337. return WriteParams(AP_FIB_BEAM_SHIFT_Y, set);
  1338. }
  1339. #endregion
  1340. #region FIB模式
  1341. /// <summary>
  1342. /// 获取FIB模式
  1343. /// </summary>
  1344. /// <returns>true:float or false:NaN</returns>
  1345. public float GetFIBMode()
  1346. {
  1347. float ret = 0;
  1348. if (ReadParams(DP_FIB_MODE, ref ret))
  1349. {
  1350. return ret;
  1351. }
  1352. else
  1353. {
  1354. return float.NaN;
  1355. }
  1356. }
  1357. #endregion
  1358. #region 工作模式选择
  1359. //SEM模式
  1360. public Boolean CmdFIBModeSEM()
  1361. {
  1362. return ExecuteCmd(CMD_FIB_MODE_SEM);
  1363. }
  1364. //FIB模式
  1365. public Boolean CmdFIBModeFIB()
  1366. {
  1367. return ExecuteCmd(CMD_FIB_MODE_FIB);
  1368. }
  1369. //铣削模式
  1370. public Boolean CmdFIBModeMILL()
  1371. {
  1372. return ExecuteCmd(CMD_FIB_MODE_MILL);
  1373. }
  1374. //SEM+FIB模式
  1375. public Boolean CmdFIBModeSEMAndFIB()
  1376. {
  1377. return ExecuteCmd(CMD_FIB_MODE_SEM_FIB);
  1378. }
  1379. //铣削+SEM模式
  1380. public Boolean CmdFIBModeMILLAndSEM()
  1381. {
  1382. return ExecuteCmd(CMD_FIB_MODE_MILL_SEM);
  1383. }
  1384. //EXT模式
  1385. public Boolean CmdFIBModeEXT()
  1386. {
  1387. return ExecuteCmd(CMD_FIB_MODE_EXT);
  1388. }
  1389. //EXT+SEM模式
  1390. public Boolean CmdFIBModeEXTAndSEM()
  1391. {
  1392. return ExecuteCmd(CMD_FIB_MODE_EXT_SEM);
  1393. }
  1394. //Argon(氩)+SEM模式
  1395. public Boolean CmdFIBModeARGONAndSEM()
  1396. {
  1397. return ExecuteCmd(CMD_FIB_MODE_ARGON_SEM);
  1398. }
  1399. //DRIFT(流)+SEM模式
  1400. public Boolean CmdFIBModeDRIFTAndSEM()
  1401. {
  1402. return ExecuteCmd(CMD_FIB_MODE_DRIFT_SEM);
  1403. }
  1404. //DRIFT(流)+FIB模式
  1405. public Boolean CmdFIBModeDRIFTAndFIB()
  1406. {
  1407. return ExecuteCmd(CMD_FIB_MODE_DRIFT_FIB);
  1408. }
  1409. //Argon(氩)模式
  1410. public Boolean CmdFIBModeARGON()
  1411. {
  1412. return ExecuteCmd(CMD_FIB_MODE_ARGON);
  1413. }
  1414. #endregion
  1415. #region 工作模式读取
  1416. /// <summary>
  1417. /// 工作模式读取
  1418. /// </summary>
  1419. /// <returns>0:SEM 1:FIB 2:MILL</returns>
  1420. public float GetFIBIMAGING()
  1421. {
  1422. float ret = 0;
  1423. if (ReadParams(DP_FIB_IMAGING, ref ret))
  1424. {
  1425. return ret;
  1426. }
  1427. else
  1428. {
  1429. return float.NaN;
  1430. }
  1431. }
  1432. #endregion
  1433. #region FIB工作状态
  1434. public float GetFIBApiStatus()
  1435. {
  1436. float ret = 0;
  1437. if (ReadParams(DP_SMARTFIB_API_STATUS, ref ret))
  1438. {
  1439. return ret;
  1440. }
  1441. else
  1442. {
  1443. return float.NaN;
  1444. }
  1445. }
  1446. #endregion
  1447. #region FIB加载.ely文件
  1448. public Boolean CmdFIBLoadELY(String _ELYFullFileName)
  1449. {
  1450. if (File.Exists(_ELYFullFileName) && Directory.Exists(ELYPATH))
  1451. {
  1452. //移动文件
  1453. if(_ELYFullFileName != ( ELYPATH + ELYFILENAME ))
  1454. {
  1455. File.Copy(_ELYFullFileName, ELYPATH + ELYFILENAME, true);
  1456. }
  1457. return ExecuteCmd(CMD_SMARTFIB_LOAD_ELY);
  1458. }
  1459. else
  1460. {
  1461. return false;
  1462. }
  1463. }
  1464. #endregion
  1465. //PT针插入
  1466. public Boolean InsertPT()
  1467. {
  1468. //插入动作
  1469. //已经插入完成
  1470. return false;
  1471. }
  1472. //PT针退出
  1473. public Boolean OutputPT()
  1474. {
  1475. return false;
  1476. }
  1477. }
  1478. }