//时间:20200610 //作者:王琦 //功能:SmartSEM remote API控制 using System; using System.Collections.Generic; using System.Linq; using System.Runtime.InteropServices; using System.Text; using System.Threading.Tasks; using APILib; using System.Threading; using System.IO; using FileManager; namespace SmartSEMControl { //可能遇到的错误提示部分??在log加入之后添加 class SmartSEM : ISEMControl { private NLog.Logger log; #region 返回错误代码枚举 private enum ZeissErrorCode { // Failed to translate parameter into an id API_E_GET_TRANSLATE_FAIL = 1000, // Failed to get analogue value API_E_GET_AP_FAIL = 1001, // Failed to get digital value API_E_GET_DP_FAIL = 1002, // Parameter supplied is not analogue nor digital API_E_GET_BAD_PARAMETER = 1003, // Failed to translate parameter into an id API_E_SET_TRANSLATE_FAIL = 1004, // Failed to set a digital state API_E_SET_STATE_FAIL = 1005, // Failed to set a float value API_E_SET_FLOAT_FAIL = 1006, // Value supplied is too low API_E_SET_FLOAT_LIMIT_LOW = 1007, // Value supplied is too high API_E_SET_FLOAT_LIMIT_HIGH = 1008, // Value supplied is is of wrong type API_E_SET_BAD_VALUE = 1009, // Parameter supplied is not analogue nor digital API_E_SET_BAD_PARAMETER = 1010, // Failed to translate command into an id API_E_EXEC_TRANSLATE_FAIL = 1011, // Failed to execute command= API_E_EXEC_CMD_FAIL = 1012, // Failed to execute file macro API_E_EXEC_MCF_FAIL = 1013, // Failed to execute library macro API_E_EXEC_MCL_FAIL = 1014, // Command supplied is not implemented API_E_EXEC_BAD_COMMAND = 1015, // Grab command failed API_E_GRAB_FAIL = 1016, // Get Stage position failed API_E_GET_STAGE_FAIL = 1017, // Move Stage position failed API_E_MOVE_STAGE_FAIL = 1018, // API not initialised API_E_NOT_INITIALISED = 1019, // Failed to translate parameter to an id API_E_NOTIFY_TRANSLATE_FAIL = 1020, // Set notification failed API_E_NOTIFY_SET_FAIL = 1021, // Get limits failed API_E_GET_LIMITS_FAIL = 1022, // Get multiple parameters failed API_E_GET_MULTI_FAIL = 1023, // Set multiple parameters failed API_E_SET_MULTI_FAIL = 1024, // Missing API license API_E_NOT_LICENSED = 1025, // Reserved or not implemented API_E_NOT_IMPLEMENTED = 1026, // Failed to get user name (Remoting Interface only) API_E_GET_USER_NAME_FAIL = 1027, // Failed to get user idle state (Remoting Interface only) API_E_GET_USER_IDLE_FAIL = 1028, // Failed to get the last remoting connection error string (Remoting Interface Only) API_E_GET_LAST_REMOTING_CONNECT_ERROR_FAIL = 1029, // Failed to remotely logon to the EM Server (username and password may be incorrect or EM Server is not running or User is already logged on API_E_EMSERVER_LOGON_FAILED = 1030, // Failed to start the EM Server - this may be because the Server is already running or has an internal error. API_E_EMSERVER_START_FAILED = 1031, // The command or parameter is currently disabled (you cannot execute or set it). API_E_PARAMETER_IS_DISABLED = 1032, // Remoting incorrectly configured, use RConfigure to correct API_E_REMOTING_NOT_CONFIGURED = 2027, // Remoting did not connect to the server API_E_REMOTING_FAILED_TO_CONNECT = 2028, // Remoting could not start (unknown reason) API_E_REMOTING_COULD_NOT_CREATE_INTERFACE = 2029, // Remoting: Remote server is not running currently. API_E_REMOTING_EMSERVER_NOT_RUNNING = 2030, // Remoting: Remote server has no user logged in API_E_REMOTING_NO_USER_LOGGED_IN = 2031, // Internal Defines, although they may be useful in your own program. TRS. API_FIRST_REMOTING_ERROR_CODE = API_E_REMOTING_NOT_CONFIGURED, API_LAST_REMOTING_ERROR_CODE = API_E_REMOTING_NO_USER_LOGGED_IN, API_FIRST_ERROR_CODE = API_E_GET_TRANSLATE_FAIL, API_LAST_ERROR_CODE = API_E_REMOTING_NO_USER_LOGGED_IN } #endregion #region 固定参数 //判断这个文件夹是否存在20200826 //private readonly String ELYPATH = @"C:\ProgramData\Carl Zeiss\SmartFIB\API\Drop\"; private readonly String ELYFILENAME = "ApiLayout.ely"; //private readonly String MLFPATH = @"C:\ProgramData\Carl Zeiss\SmartSEM\User\Service\"; private readonly String MLFFILENAME = "Opton.MLF"; private String REMOTEDesELYPATH = @""; private String REMOTEDesMLFPATH = @""; #endregion #region 模拟参数 //放大缩小 private readonly String AP_MAG = "AP_MAG"; //焦距 private readonly String AP_WD = "AP_WD"; //亮度 private readonly String AP_BRIGHTNESS = "AP_BRIGHTNESS"; //对比度 private readonly String AP_CONTRAST = "AP_CONTRAST"; //亮度目标 private readonly String AP_AUTO_BRIGHT = "AP_AUTO_BRIGHT"; //对比度目标 private readonly String AP_AUTO_CONTRAST = "AP_AUTO_CONTRAST"; //消像散X轴 private readonly String AP_STIG_X = "AP_STIG_X"; //消像散Y轴 private readonly String AP_STIG_Y = "AP_STIG_Y"; //角度补偿 private readonly String AP_TILT_ANGLE = "AP_TILT_ANGLE"; //SEM移动X private readonly String AP_BEAMSHIFT_X = "AP_BEAMSHIFT_X"; //SEM移动Y private readonly String AP_BEAMSHIFT_Y = "AP_BEAMSHIFT_Y"; //X轴移动到 private readonly String AP_STAGE_GOTO_X = "AP_STAGE_GOTO_X"; //Y轴移动到 private readonly String AP_STAGE_GOTO_Y = "AP_STAGE_GOTO_Y"; //Z轴移动到 private readonly String AP_STAGE_GOTO_Z = "AP_STAGE_GOTO_Z"; //T轴移动到 private readonly String AP_STAGE_GOTO_T = "AP_STAGE_GOTO_T"; //R轴移动到 private readonly String AP_STAGE_GOTO_R = "AP_STAGE_GOTO_R"; //M轴移动到 private readonly String AP_STAGE_GOTO_M = "AP_STAGE_GOTO_M"; //Scan Rotate角度 private readonly String AP_SCANROTATION = "AP_SCANROTATION"; //像素大小 private readonly String AP_PIXEL_SIZE = "AP_PIXEL_SIZE"; //X轴坐标 private readonly String AP_STAGE_AT_X = "AP_STAGE_AT_X"; //Y轴坐标 private readonly String AP_STAGE_AT_Y = "AP_STAGE_AT_Y"; //Z轴坐标 private readonly String AP_STAGE_AT_Z = "AP_STAGE_AT_Z"; //T轴坐标 private readonly String AP_STAGE_AT_T = "AP_STAGE_AT_T"; //R轴坐标 private readonly String AP_STAGE_AT_R = "AP_STAGE_AT_R"; //M轴坐标 private readonly String AP_STAGE_AT_M = "AP_STAGE_AT_M"; //扫描周期 private readonly String AP_FRAME_TIME = "AP_FRAME_TIME"; //FIB缩放 private readonly String AP_FIB_MAGNIFICATION = "AP_FIB_MAGNIFICATION"; //FIB焦距 private readonly String AP_FIB_OBJECTIVE_POTENTIAL = "AP_FIB_OBJECTIVE_POTENTIAL"; //FIB消像散X private readonly String AP_FIB_STIGMATOR_X = "AP_FIB_STIGMATOR_X"; //FIB消像散Y private readonly String AP_FIB_STIGMATOR_Y = "AP_FIB_STIGMATOR_Y"; //FIB光束移动X private readonly String AP_FIB_BEAM_SHIFT_X = "AP_FIB_BEAM_SHIFT_X"; //FIB光束移动Y private readonly String AP_FIB_BEAM_SHIFT_Y = "AP_FIB_BEAM_SHIFT_Y"; //SEM电压 private readonly String AP_MANUALKV = "AP_MANUALKV"; //SEM电流 private readonly String AP_IPROBE = "AP_IPROBE"; //拉直 private readonly String AP_STAGE_DELTA_R = "AP_STAGE_DELTA_R"; //光束移动位置值 private readonly String AP_BEAM_OFFSET_X = "AP_BEAM_OFFSET_X"; private readonly String AP_BEAM_OFFSET_Y = "AP_BEAM_OFFSET_Y"; private readonly String AP_NR_COEF = "AP_NR_COEF"; #endregion #region 数字参数 private readonly String DP_SCANRATE = "DP_SCANRATE"; //Scan Rotate开关 private readonly String DP_SCAN_ROT = "DP_SCAN_ROT"; //取消电子束校正 private readonly String DP_TILT_CORRECTION = "DP_TILT_CORRECTION"; //自动亮度对比度 private readonly String DP_AUTO_VIDEO = "DP_AUTO_VIDEO"; //图像解冻 private readonly String DP_FROZEN = "DP_FROZEN"; //图像类型切换 private readonly String DP_DETECTOR_TYPE = "DP_DETECTOR_TYPE"; //图像大小 private readonly String DP_IMAGE_STORE = "DP_IMAGE_STORE"; //样品台状态 private readonly String DP_STAGE_IS = "DP_STAGE_IS"; //自动函数状态 private readonly String DP_AUTO_FUNCTION = "DP_AUTO_FUNCTION"; //FIB模式 private readonly String DP_FIB_MODE = "DP_FIB_MODE"; //FIB_IMAGING private readonly String DP_FIB_IMAGING = "DP_FIB_IMAGING"; //FIB状态 private readonly String DP_SMARTFIB_API_STATUS = "DP_SMARTFIB_API_STATUS"; //FIB,ELY文件确认前,需要将该变量置为2->FIB private readonly String DP_PATTERNING_MODE = "DP_PATTERNING_MODE"; #endregion #region 命令 //20201016 设置图像速度 CMD_SCANRATE0...CMD_SCANRATE15 private readonly String CMD_SCANRATE3 = "CMD_SCANRATE3"; private readonly String CMD_SCANRATE4 = "CMD_SCANRATE4"; //add by sun 2020-12-15 拍截面图调用蔡司接口时,要保证扫描速度5以上,自动亮度对比度功能关闭 private readonly String CMD_SCANRATE5 = "CMD_SCANRATE5"; private readonly String CMD_SCANRATE6 = "CMD_SCANRATE6"; //add by sun 2020-12-15 拍截面图调用蔡司接口时,要保证扫描速度5以上,自动亮度对比度功能关闭 private readonly String CMD_SCANRATE7 = "CMD_SCANRATE7"; private readonly String CMD_SCANRATE8 = "CMD_SCANRATE8"; private readonly String CMD_SCANRATE9 = "CMD_SCANRATE9"; private readonly String CMD_SCANRATE10 = "CMD_SCANRATE10"; private readonly String CMD_LINE_AVG = "CMD_LINE_AVG"; private readonly String CMD_PIXNR = "CMD_PIXNR"; //开启电压 private readonly String CMD_BEAM_ON = "CMD_BEAM_ON"; //关闭电压 private readonly String CMD_EHT_OFF = "CMD_EHT_OFF"; //自动对焦1 private readonly String CMD_AUTO_FOCUS_COARSE = "CMD_AUTO_FOCUS_COARSE"; //自动对焦2 private readonly String CMD_AUTO_FOCUS_FINE = "CMD_AUTO_FOCUS_FINE"; //自动消像散 private readonly String CMD_AUTO_STIG = "CMD_AUTO_STIG"; //样品台急停 private readonly String CMD_STAGE_ABORT = "CMD_STAGE_ABORT"; //FIB模式选择 private readonly String CMD_FIB_MODE_SEM = "CMD_FIB_MODE_SEM"; private readonly String CMD_FIB_MODE_FIB = "CMD_FIB_MODE_FIB"; private readonly String CMD_FIB_MODE_MILL = "CMD_FIB_MODE_MILL"; private readonly String CMD_FIB_MODE_SEM_FIB = "CMD_FIB_MODE_SEM_FIB"; private readonly String CMD_FIB_MODE_MILL_SEM = "CMD_FIB_MODE_MILL_SEM"; private readonly String CMD_FIB_MODE_EXT = "CMD_FIB_MODE_EXT"; private readonly String CMD_FIB_MODE_EXT_SEM = "CMD_FIB_MODE_EXT_SEM"; private readonly String CMD_FIB_MODE_ARGON_SEM = "CMD_FIB_MODE_ARGON_SEM"; private readonly String CMD_FIB_MODE_DRIFT_SEM = "CMD_FIB_MODE_DRIFT_SEM"; private readonly String CMD_FIB_MODE_DRIFT_FIB = "CMD_FIB_MODE_DRIFT_FIB"; private readonly String CMD_FIB_MODE_ARGON = "CMD_FIB_MODE_ARGON"; //FIB加载.ely文件命令 private readonly String CMD_SMARTFIB_LOAD_ELY = "CMD_SMARTFIB_LOAD_ELY"; //FIB确认.ely文件命令 private readonly String CMD_SMARTFIB_PREPARE_EXPOSURE = "CMD_SMARTFIB_PREPARE_EXPOSURE"; //FIB开始.ley文件命令 private readonly String CMD_FIB_START_MILLING = "CMD_FIB_START_MILLING"; #endregion #region 宏文件命令 private readonly String MCF_FILENAME = "MCF_"; #endregion #region APILib private Api CZEMApi = new Api(); private Boolean m_bInitialised = false; #endregion #region 构造函数 public SmartSEM() { //LogManager.InitHardwareLog(); Init(); //判断ELY默认文件夹是否存在 //if(!Directory.Exists(ELYPATH)) //{ // Directory.CreateDirectory(ELYPATH); //} //if (!Directory.Exists(MLFPATH)) //{ // Directory.CreateDirectory(MLFPATH); //} } #endregion #region 设备初始化 /// /// 设备初始化 /// /// return:true or false public Boolean Init() { log = NLog.LogManager.GetCurrentClassLogger(); long lrt = 0; #if ROMOTE lrt = CZEMApi.InitialiseRemoting(); #else lrt = CZEMApi.Initialise(""); #endif if (lrt != 0) { log.Error("CZEMApi.Initialise Faild - " + ErrorToString(lrt), false); m_bInitialised = false; return false; } else { m_bInitialised = true; float testmag = GetMagnification(); if(!float.IsNaN(testmag)) { log.Info("CZEMApi.Initialise Success!", true); return true; } else { log.Error("CZEMApi.Initialise Faild - Disconnect", false); m_bInitialised = false; return false; } } } #endregion #region 设备远程初始化 /// /// 设备远程初始化 /// /// return:true or false public Boolean InitRemoting() { long lrt = CZEMApi.InitialiseRemoting(); if (lrt != 0) { m_bInitialised = false; return false; } else { m_bInitialised = true; return true; } } #endregion #region 连接状态 public Boolean ConnectStatus() { return m_bInitialised; } #endregion #region 关闭设备 /// /// 关闭设备 /// /// true or false public Boolean Dispose() { if (m_bInitialised) { long lrt = CZEMApi.ClosingControl(); if (lrt != 0) { log.Error("CZEMApi.ClosingControl Faild - " + ErrorToString(lrt), false); return false; } else { log.Info("CZEMApi.ClosingControl Success!", true); m_bInitialised = false; return true; } } else { return false; } } #endregion #region 读参数函数 private Boolean ReadParams(String str_param, ref float value) { if (m_bInitialised) { object varfloat = new VariantWrapper((float)0.0f); long lrt = CZEMApi.Get(str_param, ref varfloat); if (lrt != 0) { log.Error("Get " + str_param + " Faild - " + ErrorToString(lrt), false); return false; } else { value = Convert.ToSingle(varfloat); return true; } } else { log.Error("ReadParams m_bInitialised = false", false); return false; } } #endregion #region 写模拟参数函数 private Boolean WriteParams(String str_param, float value) { if (m_bInitialised) { //先取范围 object varMin = new VariantWrapper((float)0.0f); object varMax = new VariantWrapper((float)0.0f); long lrt = CZEMApi.GetLimits(str_param, ref varMin, ref varMax); if (lrt != 0) { log.Error("GetLimits " + str_param + " Faild - " + ErrorToString(lrt), false); return false; } if (value <= Convert.ToSingle(varMax) && value >= Convert.ToSingle(varMin)) { object varFloat = new VariantWrapper(value); lrt = CZEMApi.Set(str_param, ref varFloat);// set value if (lrt != 0) { log.Error("Set " + str_param + " Faild - " + ErrorToString(lrt), false); return false; } return true; } else { log.Error("Set " + str_param + " Faild - Out to range", false); return false; } } else { log.Error("ReadParams m_bInitialised = false", false); return false; } } #endregion #region 写数字参数函数 private Boolean WriteDataParams(String str_param, float value) { if (m_bInitialised) { object varFloat = new VariantWrapper(value); long lrt = CZEMApi.Set(str_param, ref varFloat);// set value if (lrt != 0) { log.Error("Set " + str_param + " Faild - " + ErrorToString(lrt), false); return false; } return true; } else { log.Error("ReadParams m_bInitialised = false", false); return false; } } #endregion #region 执行命令 private Boolean ExecuteCmd(String cmd) { if (m_bInitialised) { long lrt = CZEMApi.Execute(cmd);// execute command if (lrt != 0) { log.Error("ExecuteCmd " + cmd + " Faild - " + ErrorToString(lrt), false); return false; } else { return true; } } else { return false; } } #endregion #region SEM缩放 /// /// 读取缩放倍数 /// /// true:float or false:NaN public float GetMagnification() { float ret = 0; if(ReadParams(AP_MAG, ref ret)) { log.Info("GetMagnification " + ret.ToString() + " Success!", true); return ret; } else { log.Error("GetMagnification Faild!", false); return float.NaN; } } /// /// 设置缩放倍数 /// /// 倍数 /// true or false public Boolean SetMagnification(float set) { Boolean ret = WriteParams(AP_MAG, set); log.Info("SetMagnification = " + set.ToString(), ret); return ret; } #endregion #region SEM焦距 /// /// 读取工作距离 /// /// true:float or false:NaN public float GetWorkingDistance() { float ret = 0; if (ReadParams(AP_WD, ref ret)) { log.Info("GetWorkingDistance " + ret.ToString() + " Success!", true); return ret; } else { log.Error("GetWorkingDistance Faild!", false); return float.NaN; } } /// /// 设置焦距 /// /// 焦距 /// true or false public Boolean SetWorkingDistance(float set) { Boolean ret = WriteParams(AP_WD, set); log.Info("SetWorkingDistance = " + set.ToString(), ret); return ret; } #endregion #region 亮度 /// /// 读取亮度 /// /// true:float or false:NaN public float GetBrightness() { float ret = 0; if (ReadParams(AP_BRIGHTNESS, ref ret)) { log.Info("GetBrightness " + ret.ToString() + " Success!", true); return ret; } else { log.Error("GetBrightness Faild!", false); return float.NaN; } } /// /// 设置亮度 /// /// 亮度 /// true or false public Boolean SetBrightness(float set) { Boolean ret = WriteParams(AP_BRIGHTNESS, set); log.Info("SetBrightness = " + set.ToString(), ret); return ret; } #endregion #region 对比度 /// /// 读取对比度 /// /// true:float or false:NaN public float GetContrast() { float ret = 0; if (ReadParams(AP_CONTRAST, ref ret)) { log.Info("GetContrast " + ret.ToString() + " Success!", true); return ret; } else { log.Error("GetContrast Faild!", false); return float.NaN; } } /// /// 设置对比度 /// /// 对比度 /// true or false public Boolean SetContrast(float set) { Boolean ret = WriteParams(AP_CONTRAST, set); log.Info("SetContrast = " + set.ToString(), ret); return ret; } #endregion #region 自动亮度对比度 /// /// 读取自动亮度对比度状态 /// /// true:float or false:NaN public float GetAutoVideo() { float ret = 0; if (ReadParams(DP_AUTO_VIDEO, ref ret)) { log.Info("GetAutoVideo " + ret.ToString() + " Success!", true); return ret; } else { log.Error("GetAutoVideo Faild!", false); return float.NaN; } } /// /// 设置自动亮度对比度状态 /// /// 0:off;1:B(亮度);2:C(对比度);3:BC /// true or false public Boolean SetAutoVideoOff() { Boolean ret = WriteDataParams(DP_AUTO_VIDEO, (float)0); log.Info("SetAutoVideoOff", ret); return ret; } public Boolean SetAutoVideoBrightness() { Boolean ret = WriteDataParams(DP_AUTO_VIDEO, (float)1); log.Info("SetAutoVideoBrightness", ret); return ret; } public Boolean SetAutoVideoContrast() { Boolean ret = WriteDataParams(DP_AUTO_VIDEO, (float)2); log.Info("SetAutoVideoContrast", ret); return ret; } public Boolean SetAutoVideoBrightnessAndContrast() { Boolean ret = WriteDataParams(DP_AUTO_VIDEO, (float)3); log.Info("SetAutoVideoBrightnessAndContrast", ret); return ret; } #endregion #region 亮度目标 /// /// 读取亮度目标 /// /// true:float or false:NaN public float GetAutoBright() { float ret = 0; if (ReadParams(AP_AUTO_BRIGHT, ref ret)) { log.Info("GetAutoBright " + ret.ToString() + " Success!", true); return ret; } else { log.Info("GetAutoBright Faild!", false); return float.NaN; } } /// /// 设置亮度目标 /// /// 亮度 /// true or false public Boolean SetAutoBright(float set) { Boolean ret = WriteParams(AP_AUTO_BRIGHT, set); log.Info("SetAutoBright = " + set.ToString(), ret); return ret; } #endregion #region 对比度目标 /// /// 读取对比度目标 /// /// true:float or false:NaN public float GetAutoContrast() { float ret = 0; if (ReadParams(AP_AUTO_CONTRAST, ref ret)) { log.Info("GetAutoContrast " + ret.ToString() + " Success!", true); return ret; } else { log.Error("GetAutoContrast Faild!", false); return float.NaN; } } /// /// 设置对比度目标 /// /// 对比度目标 /// true or false public Boolean SetAutoContrast(float set) { Boolean ret = WriteParams(AP_AUTO_CONTRAST, set); log.Info("SetAutoContrast = " + set.ToString(), ret); return ret; } #endregion #region SEM消像散 /// /// 读取消像散X /// /// true:float or false:NaN public float GetAstigmatismX() { float ret = 0; if (ReadParams(AP_STIG_X, ref ret)) { log.Info("GetAstigmatismX " + ret.ToString() + " Success!", true); return ret; } else { log.Error("GetAstigmatismX Faild!", false); return float.NaN; } } /// /// 读取消像散Y /// /// true:float or false:NaN public float GetAstigmatismY() { float ret = 0; if (ReadParams(AP_STIG_Y, ref ret)) { log.Info("GetAstigmatismY " + ret.ToString() + " Success!", true); return ret; } else { log.Error("GetAstigmatismY Faild!", false); return float.NaN; } } /// /// 设置消像散X /// /// 对比度 /// true or false public Boolean SetAstigmatismX(float set) { Boolean ret = WriteParams(AP_STIG_X, set); log.Info("SetAstigmatismX = " + set.ToString(), ret); return ret; } /// /// 设置消像散Y /// /// 对比度 /// true or false public Boolean SetAstigmatismY(float set) { Boolean ret = WriteParams(AP_STIG_Y, set); log.Info("SetAstigmatismY = " +set.ToString(), ret); return ret; } #endregion #region 角度补偿 /// /// 读取角度补偿 /// /// true:float or false:NaN public float GetTiltAngle() { float ret = 0; if (ReadParams(AP_TILT_ANGLE, ref ret)) { log.Info("GetTiltAngle " + ret.ToString() + " Success!", true); return ret; } else { log.Error("GetTiltAngle Faild!", false); return float.NaN; } } /// /// 角度补偿解锁 /// /// public Boolean SetTiltAngleOn() { Boolean ret = WriteDataParams(DP_TILT_CORRECTION, 1); log.Info("Set DP_TILT_CORRECTION = 1.", ret); return ret; } /// /// 角度补偿锁定 /// /// public Boolean SetTiltAngleOff() { Boolean ret = WriteDataParams(DP_TILT_CORRECTION, 0); log.Info("Set DP_TILT_CORRECTION = 0.", ret); return ret; } /// /// 设置角度补偿 /// /// 角度补偿 /// true or false public Boolean SetTiltAngle(float set) { Boolean ret = false; //ret = WriteDataParams(DP_TILT_CORRECTION, 1); //log.Info("Set DP_TILT_CORRECTION = 1.", ret); ret = WriteParams(AP_TILT_ANGLE, set); log.Info("SetTiltAngle = " + set.ToString(), ret); //ret = WriteDataParams(DP_TILT_CORRECTION, 0); //log.Info("Set DP_TILT_CORRECTION = 0.", ret); return ret; } #endregion #region 图像大小 public int[] GetImageStore() { int[] i_ret = new int[2]; float ret = 0; if (ReadParams(DP_IMAGE_STORE, ref ret)) { switch (ret) { case 0: i_ret[0] = 1024; i_ret[1] = 768; break; case 1: i_ret[0] = 512; i_ret[1] = 384; break; case 2: i_ret[0] = 2048; i_ret[1] = 1536; break; case 3: i_ret[0] = 3072; i_ret[1] = 2304; break; case 4: i_ret[0] = 4096; i_ret[1] = 3072; break; case 5: i_ret[0] = 5120; i_ret[1] = 3840; break; case 6: i_ret[0] = 6144; i_ret[1] = 4608; break; case 7: i_ret[0] = 8192; i_ret[1] = 6144; break; case 8: i_ret[0] = 12288; i_ret[1] = 9216; break; case 9: i_ret[0] = 16384; i_ret[1] = 12288; break; case 10: i_ret[0] = 24576; i_ret[1] = 18432; break; case 11: i_ret[0] = 32768; i_ret[1] = 24576; break; default: i_ret[0] = 0; i_ret[1] = 0; break; } log.Info("GetImageStore=" + i_ret[0].ToString() + "*" + i_ret[1].ToString(), true); } else { log.Error("GetImageStore Faild!", false); i_ret[0] = 0; i_ret[1] = 0; } return i_ret; } public Boolean SetImageStore(float set) { Boolean ret = WriteDataParams("DP_IMAGE_STORE", set); log.Info("SetImageStore = " + set.ToString(), ret); return ret; } #endregion #region 扫描周期 public float GetCycleTime() { float ret = 0; if (ReadParams(AP_FRAME_TIME, ref ret)) { log.Info("GetCycleTime=" + ret.ToString(), true); } else { log.Error("GetCycleTime Faild!", false); } return ret; } #endregion #region SEM电压 /// /// 读取电压 /// /// true:float or false:NaN public float GetSEMVoltage() { float ret = 0; if (ReadParams(AP_MANUALKV, ref ret)) { log.Info("SEM_Voltage " + ret.ToString() + " Success!", true); return ret; } else { log.Error("SEM_Voltage Faild!", false); return float.NaN; } } /// /// 设置电压 /// /// 电压 /// true or false public Boolean SetSEMVoltage(float set) { Boolean ret = WriteParams(AP_MANUALKV, set); log.Info("SetSEMVoltage = " + set.ToString(), ret); return ret; } #endregion #region SEM电流 /// /// 读取电流 /// /// true:float or false:NaN public float GetSEMIPROBE() { float ret = 0; if (ReadParams(AP_IPROBE, ref ret)) { log.Info("SEM_IPROBE " + ret.ToString() + " Success!", true); return ret; } else { log.Error("SEM_IPROBE Faild!", false); return float.NaN; } } /// /// 设置电流 /// /// 电流 /// true or false public Boolean SetSEMIPROBE(float set) { Boolean ret = WriteParams(AP_IPROBE, set); log.Info("SetSEMIPROBE = " + set.ToString(), ret); return ret; } #endregion #region 抓取图像 /// /// 抓取图像 /// /// true:float or false:NaN public Boolean GrabImage(String filename, short xoff,short yoff, short width,short height,short type) { if (m_bInitialised) { long lrt = CZEMApi.Grab(xoff, yoff, width, height, type, filename); if (lrt != 0) { log.Error("GrabImage Faild!", false); return false; } else { log.Info("GrabImage Filename=" + filename + ",x,y,w,h,type=" + xoff.ToString() + "," + yoff.ToString() + "," + width.ToString() + "," + height.ToString() + "," + type.ToString(), true); while (true) { Thread.Sleep(1000); float sta = GetImageFrozen(); if (sta == 1) { log.Info("ImageLive", true); ImageLive(); break; } } return true; } } else { log.Error("GrabImage m_bInitialised = False!", false); return false; } } #endregion #region 小面积抓取图像 /// /// 小面积抓取图像 /// /// true:float or false:NaN public Boolean GrabZoneImage(String filename, short xoff, short yoff, short width, short height, short type) { if (m_bInitialised) { float frametime = 0; ReadParams("AP_FRAME_TIME", ref frametime); ExecuteCmd("CMD_UNFREEZE_ZONE"); Thread.Sleep((int)frametime + 200); ExecuteCmd("CMD_FREEZE_ZONE"); Thread.Sleep((int)frametime + 200); CZEMApi.Grab(xoff, yoff, width, height, type, filename); return true; } else { log.Error("GrabImage m_bInitialised = False!", false); return false; } } #endregion #region 图像解冻 public float GetImageFrozen() { float ret = 0; if (ReadParams(DP_FROZEN, ref ret)) { log.Info("GetImageFrozen " + ret.ToString() + " Success!", true); return ret; } else { log.Error("GetImageFrozen Faild!", false); return float.NaN; } } public Boolean ImageFrozen() { Boolean ret = WriteDataParams(DP_FROZEN, (float)1); log.Info("ImageFrozen!", ret); return ret; } public Boolean ImageLive() { Boolean ret = WriteDataParams(DP_FROZEN, (float)0); log.Info("ImageLive!", ret); return ret; } #endregion #region 图像类型切换 public Boolean DetectorType(float set) { Boolean ret = WriteDataParams(DP_DETECTOR_TYPE, set); log.Info("DetectorType = " + set.ToString(), ret); return ret; } #endregion #region SEM电子束移动接口 /// /// 获取电子束移动接口X /// /// true:float or false:NaN public float GetBeamShiftX() { float ret = 0; if (ReadParams(AP_BEAMSHIFT_X, ref ret)) { log.Info("GetBeamShiftX " + ret.ToString() + " Success!", true); return ret; } else { log.Error("GetBeamShiftX Faild!", false); return float.NaN; } } /// /// 获取电子束移动接口Y /// /// true:float or false:NaN public float GetBeamShiftY() { float ret = 0; if (ReadParams(AP_BEAMSHIFT_Y, ref ret)) { log.Info("GetBeamShiftY " + ret.ToString() + " Success!", true); return ret; } else { log.Error("GetBeamShiftY Faild!", false); return float.NaN; } } /// /// 设置电子束移动接口X /// /// X坐标 /// true or false public Boolean SetBeamShiftX(float set) { Boolean ret = WriteParams(AP_BEAMSHIFT_X, set); log.Info("SetBeamShiftX=" + set.ToString(), ret); return ret; } /// /// 设置电子束移动接口Y /// /// X坐标 /// true or false public Boolean SetBeamShiftY(float set) { Boolean ret = WriteParams(AP_BEAMSHIFT_Y, set); log.Info("SetBeamShiftY=" + set.ToString(), ret); return ret; } #endregion #region SEM电子束移动距离接口 /// /// 获取电子束移动距离接口X值 /// /// true:float or false:NaN public float GetBeamOffsetX() { float ret = 0; if (ReadParams(AP_BEAM_OFFSET_X, ref ret)) { log.Info("AP_BEAM_OFFSET_X " + ret.ToString() + " Success!", true); return ret; } else { log.Error("AP_BEAM_OFFSET_X Faild!", false); return float.NaN; } } /// /// 获取电子束移动距离接口Y值 /// /// true:float or false:NaN public float GetBeamOffsetY() { float ret = 0; if (ReadParams(AP_BEAM_OFFSET_Y, ref ret)) { log.Info("AP_BEAM_OFFSET_Y " + ret.ToString() + " Success!", true); return ret; } else { log.Error("AP_BEAM_OFFSET_Y Faild!", false); return float.NaN; } } /// /// 设置电子束移动距离接口X值 /// /// X坐标 /// true or false public Boolean SetBeamOffsetX(float set) { Boolean ret = WriteParams(AP_BEAM_OFFSET_X, set); log.Info("AP_BEAM_OFFSET_X=" + set.ToString(), ret); return ret; } /// /// 设置电子束移动接口Y /// /// X坐标 /// true or false public Boolean SetBeamOffsetY(float set) { Boolean ret = WriteParams(AP_BEAM_OFFSET_Y, set); log.Info("AP_BEAM_OFFSET_Y=" + set.ToString(), ret); return ret; } #endregion #region 样品台移动接口 /// /// 返回样品台坐标数组 /// /// Lenght=6 public float[] GetStagePosition() { object retx = new VariantWrapper((float)0.0f); object rety = new VariantWrapper((float)0.0f); object retz = new VariantWrapper((float)0.0f); object rett = new VariantWrapper((float)0.0f); object retr = new VariantWrapper((float)0.0f); object retm = new VariantWrapper((float)0.0f); float[] ret = new float[6]; if (m_bInitialised) { CZEMApi.GetStagePosition(ref retx, ref rety, ref retz, ref rett, ref retr, ref retm); ret[0] = Convert.ToSingle(retx); ret[1] = Convert.ToSingle(rety); ret[2] = Convert.ToSingle(retz); ret[3] = Convert.ToSingle(rett); ret[4] = Convert.ToSingle(retr); ret[5] = Convert.ToSingle(retm); log.Info("GetStagePosition x,y,z,t,r,m = " + retx.ToString() + "," + rety.ToString() + "," + retz.ToString() + "," + rett.ToString() + "," + retr.ToString() + "," + retm.ToString(), true); } else { ret[0] = float.NaN; ret[1] = float.NaN; ret[2] = float.NaN; ret[3] = float.NaN; ret[4] = float.NaN; ret[5] = float.NaN; log.Error("GetStagePosition Faild!", false); } return ret; } /// /// 设置样品台坐标数组 /// /// Lenght=6 private Boolean SetStagePosition(float[] set) { if (m_bInitialised) { long lrt = CZEMApi.MoveStage(set[0], set[1], set[2], set[3], set[4], set[5]); if(lrt==0) { log.Info("SetStagePosition x,y,z,t,r,m = " + set[0].ToString() + "," + set[1].ToString() + "," + set[2].ToString() + "," + set[3].ToString() + "," + set[4].ToString() + "," + set[5].ToString(), true); return true; } else { log.Error("SetStagePosition Faild!", false); return false; } } else { log.Error("SetStagePosition m_bInitialised = false!", false); return false; } } /// /// 样品台位置 X轴 /// /// true:float or false:NaN public float GetStageAtX() { float ret = 0; if (ReadParams(AP_STAGE_AT_X, ref ret)) { log.Info("GetStageAtX Success!", true); return ret; } else { log.Error("GetStageAtX Faild!", false); return float.NaN; } } /// /// 样品台位置 Y轴 /// /// true:float or false:NaN public float GetStageAtY() { float ret = 0; if (ReadParams(AP_STAGE_AT_Y, ref ret)) { log.Info("GetStageAtY Success!", true); return ret; } else { log.Error("GetStageAtY Faild!", false); return float.NaN; } } /// /// 样品台位置 Z轴 /// /// true:float or false:NaN public float GetStageAtZ() { float ret = 0; if (ReadParams(AP_STAGE_AT_Z, ref ret)) { log.Info("GetStageAtZ Success!", true); return ret; } else { log.Error("GetStageAtZ Faild!", false); return float.NaN; } } /// /// 样品台位置 T轴 /// /// true:float or false:NaN public float GetStageAtT() { float ret = 0; if (ReadParams(AP_STAGE_AT_T, ref ret)) { log.Info("GetStageAtT Success!", true); return ret; } else { log.Error("GetStageAtT Faild!", false); return float.NaN; } } /// /// 样品台位置 R轴 /// /// true:float or false:NaN public float GetStageAtR() { float ret = 0; if (ReadParams(AP_STAGE_AT_R, ref ret)) { log.Info("GetStageAtR Success!", true); return ret; } else { log.Error("GetStageAtR Faild!", false); return float.NaN; } } /// /// 样品台位置 M轴 /// /// true:float or false:NaN public float GetStageAtM() { float ret = 0; if (ReadParams(AP_STAGE_AT_M, ref ret)) { log.Info("GetStageAtM Success!", true); return ret; } else { log.Error("GetStageAtM Faild!", false); return float.NaN; } } /// /// 样品台位置 X轴 /// /// X轴移动坐标 /// public Boolean SetStageGotoX(float set) { Boolean ret = WriteParams(AP_STAGE_GOTO_X, set); log.Info("SetStageGotoX = " + set.ToString(), ret); return ret; } /// /// 样品台位置 Y轴 /// /// Y轴移动坐标 /// public Boolean SetStageGotoY(float set) { Boolean ret = WriteParams(AP_STAGE_GOTO_Y, set); log.Info("SetStageGotoY = " + set.ToString(), ret); return ret; } /// /// 样品台位置 Z轴 /// /// Y轴移动坐标 /// public Boolean SetStageGotoZ(float set) { Boolean ret = WriteParams(AP_STAGE_GOTO_Z, set); log.Info("SetStageGotoZ = " + set.ToString(), ret); return ret; } /// /// 样品台位置 T轴 /// /// Y轴移动坐标 /// public Boolean SetStageGotoT(float set) { Boolean ret = WriteParams(AP_STAGE_GOTO_T, set); log.Info("SetStageGotoT = " + set.ToString(), ret); return ret; } /// /// 样品台位置 R轴 /// /// Y轴移动坐标 /// public Boolean SetStageGotoR(float set) { Boolean ret = WriteParams(AP_STAGE_GOTO_R, set); log.Info("SetStageGotoR = " + set.ToString(), ret); return ret; } /// /// 样品台位置 R轴拉直 /// /// R轴拉直角度 /// public Boolean SetStageDeltaR(float set) { Boolean ret = WriteParams(AP_STAGE_DELTA_R, set); log.Info("AP_STAGE_DELTA_R = " + set.ToString(), ret); return ret; } /// /// 样品台位置 M轴 /// /// M轴移动坐标 /// public Boolean SetStageGotoM(float set) { Boolean ret = WriteParams(AP_STAGE_GOTO_M, set); log.Info("SetStageGotoM = " + set.ToString(), ret); return ret; } #endregion #region 移动样品台XY轴 public Boolean MoveStageXY(float x,float y) { //先取范围 object xMin = new VariantWrapper((float)0.0f); object xMax = new VariantWrapper((float)0.0f); long lrt = CZEMApi.GetLimits(AP_STAGE_GOTO_X, ref xMin, ref xMax); if (lrt != 0) { log.Error("GetLimits AP_STAGE_GOTO_X Faild!", false); return false; } if (x > Convert.ToSingle(xMax) || x < Convert.ToSingle(xMin)) { log.Error("GetLimits AP_STAGE_GOTO_X Max,Min,x = " + xMax.ToString() + "," + xMin.ToString() + "," + x.ToString(), false); return false; } object yMin = new VariantWrapper((float)0.0f); object yMax = new VariantWrapper((float)0.0f); lrt = CZEMApi.GetLimits(AP_STAGE_GOTO_Y, ref yMin, ref yMax); if (lrt != 0) { log.Error("GetLimits AP_STAGE_GOTO_Y Faild!", false); return false; } if (y > Convert.ToSingle(yMax) || y < Convert.ToSingle(yMin)) { log.Error("GetLimits AP_STAGE_GOTO_Y Max,Min,y = " + yMax.ToString() + "," + yMin.ToString() + "," + y.ToString(), false); return false; } float[] gsp = GetStagePosition(); gsp[0] = x; gsp[1] = y; return SetStagePosition(gsp); } #endregion #region 样品台急停 public Boolean CmdStageAbort() { Boolean ret = ExecuteCmd(CMD_STAGE_ABORT); log.Info("CmdStageAbort!", ret); return ret; } #endregion #region Scan Rotate角度接口 /// /// 获取Scan Rotate角度接口 /// /// true:float or false:NaN public float GetScanRotation() { float ret = 0; if (ReadParams(AP_SCANROTATION, ref ret)) { log.Info("GetScanRotation Success!", true); return ret; } else { log.Error("GetScanRotation Faild!", false); return float.NaN; } } /// /// ScanRotation解锁 /// /// public Boolean SetScanRotationOn() { Boolean ret = WriteDataParams(DP_SCAN_ROT, 1); log.Info("SetScanRotation DP_SCAN_ROT = 1", ret); return ret; } /// /// ScanRotation锁定 /// /// public Boolean SetScanRotationOff() { Boolean ret = WriteDataParams(DP_SCAN_ROT, 0); log.Info("SetScanRotation DP_SCAN_ROT = 0", ret); return ret; } /// /// 设置Scan Rotate角度接口 /// /// 角度补偿 /// true or false public Boolean SetScanRotation(float set) { Boolean ret = false; //ret = WriteDataParams(DP_SCAN_ROT, 1); //log.Info("SetScanRotation DP_SCAN_ROT = 1", ret); ret = WriteParams(AP_SCANROTATION, set); log.Info("SetScanRotation = " + set.ToString(), ret); //ret = WriteDataParams(DP_SCAN_ROT, 0); //log.Info("SetScanRotation DP_SCAN_ROT = 0", ret); return ret; } #endregion #region 像素读取PixelSize /// /// 获取Pixel Size 接口,只读 /// /// true:float or false:NaN public float GetPixelSize() { float ret = 0; if (ReadParams(AP_PIXEL_SIZE, ref ret)) { log.Info("GetPixelSize " + ret.ToString() + " Success!", true); return ret; } else { log.Info("GetPixelSize Faild!", false); return float.NaN; } } #endregion #region 电子束校正设置 /// /// 读取电子束校正状态 /// /// public float GetTiltCorrection() { float ret = 0; if (ReadParams(DP_TILT_CORRECTION, ref ret)) { log.Info("GetTiltCorrection " + ret.ToString() + " Success!", true); return ret; } else { log.Error("GetTiltCorrection Faild!", false); return float.NaN; } } /// /// 设置电子束校正状态 /// /// /// public Boolean SetTiltCorrectionOff() { Boolean ret = WriteDataParams(DP_TILT_CORRECTION, (float)0); log.Info("SetTiltCorrectionOff!", ret); return ret; } public Boolean SetTiltCorrectionOn() { Boolean ret = WriteDataParams(DP_TILT_CORRECTION, (float)1); log.Info("SetTiltCorrectionOn!", ret); return ret; } #endregion #region 开启电压 public Boolean CmdOpenVoltage() { Boolean ret = ExecuteCmd(CMD_BEAM_ON); log.Info("CmdOpenVoltage!", ret); return ret; } #endregion #region 关闭电压 public Boolean CmdCloseVoltage() { Boolean ret = ExecuteCmd(CMD_EHT_OFF); log.Info("CmdCloseVoltage!", ret); return ret; } #endregion #region 自动对焦1 public Boolean CmdAutoFocusCoarse() { Boolean ret = ExecuteCmd(CMD_AUTO_FOCUS_COARSE); log.Info("CmdAutoFocusCoarse!", ret); return ret; } #endregion #region 自动对焦2 public Boolean CmdAutoFocusFine() { Boolean ret = ExecuteCmd(CMD_AUTO_FOCUS_FINE); log.Info("CmdAutoFocusFine!", ret); return ret; } #endregion #region 自动消像散 public Boolean CmdAutoStig() { Boolean ret = ExecuteCmd(CMD_AUTO_STIG); log.Info("CmdAutoStig!", ret); return ret; } #endregion #region 调用宏文件命令 public Boolean CMDMCFFilename(String _MLFFullFileName) { //String CMDMCF = MCF_FILENAME + filename; //Boolean ret = ExecuteCmd(CMDMCF); //log.Info("CMDMCFFilename = " + filename, ret); //return ret; if (File.Exists(_MLFFullFileName) ) { //移动文件 //if (_MLFFullFileName != (MLFPATH + MLFFILENAME)) //{ // File.Copy(_MLFFullFileName, MLFPATH + MLFFILENAME, true); // log.Info("CmdFIBLoadMLF Copy FileName:" + _MLFFullFileName + " To " + MLFPATH + MLFFILENAME, true); // try // { if (REMOTEDesMLFPATH != "") { File.Copy(_MLFFullFileName, REMOTEDesMLFPATH + MLFFILENAME, true); log.Info("CmdFIBLoadELY Success Execute " + _MLFFullFileName + "to " + REMOTEDesMLFPATH + MLFFILENAME); } // } // catch { } //} Boolean ret = ExecuteCmd(MCF_FILENAME + MLFFILENAME.Substring(0,MLFFILENAME.Length-4)); log.Info("CmdFIBLoadMLF Success Execute " + _MLFFullFileName, true); return ret; } else { log.Error("CmdFIBLoadMLF Faild:" + _MLFFullFileName + " Is Not Exists!", false); return false; } } #endregion #region 读取样品台状态 public float GetStageIs() { float ret = 0; if (ReadParams(DP_STAGE_IS, ref ret)) { log.Info("GetStageIs " + ret.ToString() + " Success!", true); return ret; } else { log.Error("GetStageIs Faild!", false); return float.NaN; } } #endregion #region 读取自动函数的状态 public float GetAutoFunction() { float ret = 0; if (ReadParams(DP_AUTO_FUNCTION, ref ret)) { log.Info("GetAutoFunction " + ret.ToString() + " Success!", true); return ret; } else { log.Error("GetAutoFunction Faild!", false); return float.NaN; } } #endregion #region FIB缩放 /// /// 读取缩放倍数 /// /// true:float or false:NaN public float GetFIBMagnification() { float ret = 0; if (ReadParams(AP_FIB_MAGNIFICATION, ref ret)) { log.Info("GetFIBMagnification " + ret.ToString() + " Success!", true); return ret; } else { log.Error("GetFIBMagnification Faild!", false); return float.NaN; } } /// /// 设置缩放倍数 /// /// 倍数 /// true or false public Boolean SetFIBMagnification(float set) { Boolean ret = WriteParams(AP_FIB_MAGNIFICATION, set); log.Info("GSetFIBMagnification = " + set.ToString(), ret); return ret; } #endregion #region FIB焦距 /// /// 读取工作距离AP_FIB_OBJECTIVE_POTENTIAL /// /// true:float or false:NaN public float GetFIBObjectivePotential() { float ret = 0; if (ReadParams(AP_FIB_OBJECTIVE_POTENTIAL, ref ret)) { log.Info("GetFIBObjectivePotential " + ret.ToString() + " Success!", true); return ret; } else { log.Error("GetFIBObjectivePotential Faild!", false); return float.NaN; } } /// /// 设置焦距 /// /// 焦距 /// true or false public Boolean SetFIBObjectivePotential(float set) { Boolean ret = WriteParams(AP_FIB_OBJECTIVE_POTENTIAL, set); log.Info("SetFIBObjectivePotential = " + set.ToString(), ret); return ret; } #endregion #region FIB消像散 /// /// 读取消像散X /// /// true:float or false:NaN public float GetFIBAstigmatismX() { float ret = 0; if (ReadParams(AP_FIB_STIGMATOR_X, ref ret)) { log.Info("GetFIBAstigmatismX " + ret.ToString() + " Success!", true); return ret; } else { log.Error("GetFIBAstigmatismX Faild!", false); return float.NaN; } } /// /// 读取消像散Y /// /// true:float or false:NaN public float GetFIBAstigmatismY() { float ret = 0; if (ReadParams(AP_FIB_STIGMATOR_Y, ref ret)) { log.Info("GetFIBAstigmatismY " + ret.ToString() + " Success!", true); return ret; } else { log.Error("GetFIBAstigmatismY Faild!", false); return float.NaN; } } /// /// 设置消像散X /// /// 对比度 /// true or false public Boolean SetFIBAstigmatismX(float set) { Boolean ret = WriteParams(AP_FIB_STIGMATOR_X, set); log.Info("SetFIBAstigmatismX = " + set.ToString(), ret); return ret; } /// /// 设置消像散Y /// /// 对比度 /// true or false public Boolean SetFIBAstigmatismY(float set) { Boolean ret = WriteParams(AP_FIB_STIGMATOR_Y, set); log.Info("SetFIBAstigmatismY = " + set.ToString(), ret); return ret; } #endregion #region FIB电子束移动接口 /// /// 获取电子束移动接口X /// /// true:float or false:NaN public float GetFIBBeamShiftX() { float ret = 0; if (ReadParams(AP_FIB_BEAM_SHIFT_X, ref ret)) { log.Info("GetFIBBeamShiftX " + ret.ToString() + " Success!", true); return ret; } else { log.Error("GetFIBBeamShiftX Faild!", false); return float.NaN; } } /// /// 获取电子束移动接口Y /// /// true:float or false:NaN public float GetFIBBeamShiftY() { float ret = 0; if (ReadParams(AP_FIB_BEAM_SHIFT_Y, ref ret)) { log.Info("GetFIBBeamShiftY " + ret.ToString() + " Success!", true); return ret; } else { log.Error("GetFIBBeamShiftY Faild!", false); return float.NaN; } } /// /// 设置电子束移动接口X /// /// X坐标 /// true or false public Boolean SetFIBBeamShiftX(float set) { Boolean ret = WriteParams(AP_FIB_BEAM_SHIFT_X, set); log.Info("SetFIBBeamShiftX = " + set.ToString(), ret); return ret; } /// /// 设置电子束移动接口Y /// /// X坐标 /// true or false public Boolean SetFIBBeamShiftY(float set) { Boolean ret = WriteParams(AP_FIB_BEAM_SHIFT_Y, set); log.Info("SetFIBBeamShiftX = " + set.ToString(), ret); return ret; } #endregion #region FIB模式 /// /// 获取FIB模式 /// /// true:float or false:NaN public float GetFIBMode() { float ret = 0; if (ReadParams(DP_FIB_MODE, ref ret)) { log.Info("GetFIBMode " + ret.ToString() + " Success!", true); return ret; } else { log.Error("GetFIBMode Faild!", false); return float.NaN; } } #endregion #region 工作模式选择 //SEM模式 public Boolean CmdFIBModeSEM() { Boolean ret = ExecuteCmd(CMD_FIB_MODE_SEM); log.Info("CmdFIBModeSEM = SEM!", ret); return ret; } //FIB模式 public Boolean CmdFIBModeFIB() { Boolean ret = ExecuteCmd(CMD_FIB_MODE_FIB); log.Info("CmdFIBModeSEM = FIB!", ret); return ret; } //铣削模式 public Boolean CmdFIBModeMILL() { Boolean ret = ExecuteCmd(CMD_FIB_MODE_MILL); log.Info("CmdFIBModeSEM = MILL!", ret); return ret; } //SEM+FIB模式 public Boolean CmdFIBModeSEMAndFIB() { return ExecuteCmd(CMD_FIB_MODE_SEM_FIB); } //铣削+SEM模式 public Boolean CmdFIBModeMILLAndSEM() { return ExecuteCmd(CMD_FIB_MODE_MILL_SEM); } //EXT模式 public Boolean CmdFIBModeEXT() { return ExecuteCmd(CMD_FIB_MODE_EXT); } //EXT+SEM模式 public Boolean CmdFIBModeEXTAndSEM() { return ExecuteCmd(CMD_FIB_MODE_EXT_SEM); } //Argon(氩)+SEM模式 public Boolean CmdFIBModeARGONAndSEM() { return ExecuteCmd(CMD_FIB_MODE_ARGON_SEM); } //DRIFT(流)+SEM模式 public Boolean CmdFIBModeDRIFTAndSEM() { return ExecuteCmd(CMD_FIB_MODE_DRIFT_SEM); } //DRIFT(流)+FIB模式 public Boolean CmdFIBModeDRIFTAndFIB() { return ExecuteCmd(CMD_FIB_MODE_DRIFT_FIB); } //Argon(氩)模式 public Boolean CmdFIBModeARGON() { return ExecuteCmd(CMD_FIB_MODE_ARGON); } #endregion #region 工作模式读取 /// /// 工作模式读取 /// /// 0:SEM 1:FIB 2:MILL public float GetFIBIMAGING() { float ret = 0; if (ReadParams(DP_FIB_IMAGING, ref ret)) { log.Info("GetFIBIMAGING " + ret.ToString() + " Success!", true); return ret; } else { log.Error("GetFIBIMAGING Faild!", false); return float.NaN; } } #endregion #region FIB工作状态 public float GetFIBApiStatus() { float ret = 0; if (ReadParams(DP_SMARTFIB_API_STATUS, ref ret)) { log.Info("GetFIBApiStatus " + ret.ToString() + " Success!", true); return ret; } else { log.Error("GetFIBApiStatus Faild!", false); return float.NaN; } } #endregion #region FIB加载.ely文件 public Boolean CmdFIBLoadELY(String _ELYFullFileName) { if (File.Exists(_ELYFullFileName) ) { if (REMOTEDesELYPATH != "") { File.Copy(_ELYFullFileName, REMOTEDesELYPATH + ELYFILENAME, true); log.Info("copy " + _ELYFullFileName + " to " + REMOTEDesELYPATH + ELYFILENAME); } Boolean ret = ExecuteCmd(CMD_SMARTFIB_LOAD_ELY); log.Info("CmdFIBLoadELY Success Execute " + _ELYFullFileName, true); return ret; } else { log.Error("CmdFIBLoadELY Faild:" + _ELYFullFileName + " Is Not Exists!", false); return false; } } #endregion #region FIB确认.ely文件 public Boolean CmdFIBEXPOSUREELY() { Boolean ret = WriteDataParams(DP_PATTERNING_MODE, 2); log.Info("DP_PATTERNING_MODE = 2", ret); ret = ExecuteCmd(CMD_SMARTFIB_PREPARE_EXPOSURE); log.Info("CMD_SMARTFIB_PREPARE_EXPOSURE", ret); return ret; } #endregion #region FIB执行.ely文件 public Boolean CmdFIBSTARTELY() { Boolean ret = ExecuteCmd(CMD_FIB_START_MILLING); log.Info("CMD_FIB_START_MILLING", ret); return ret; } #endregion #region 错误代码转义 private String ErrorToString(long lError) { string strError; switch ((ZeissErrorCode)lError) { case 0: strError = "OK"; break; case ZeissErrorCode.API_E_GET_TRANSLATE_FAIL: strError = "Failed to translate parameter into an ID"; break; case ZeissErrorCode.API_E_GET_AP_FAIL: strError = "Failed to get analogue value"; break; case ZeissErrorCode.API_E_GET_DP_FAIL: strError = "Failed to get digital value"; break; case ZeissErrorCode.API_E_GET_BAD_PARAMETER: strError = "Parameter supplied is neither analogue nor digital"; break; case ZeissErrorCode.API_E_SET_TRANSLATE_FAIL: strError = "Failed to translate parameter into an ID"; break; case ZeissErrorCode.API_E_SET_STATE_FAIL: strError = "Failed to set a digital state"; break; case ZeissErrorCode.API_E_SET_FLOAT_FAIL: strError = "Failed to set a float value"; break; case ZeissErrorCode.API_E_SET_FLOAT_LIMIT_LOW: strError = "Value supplied is too low"; break; case ZeissErrorCode.API_E_SET_FLOAT_LIMIT_HIGH: strError = "Value supplied is too high"; break; case ZeissErrorCode.API_E_SET_BAD_VALUE: strError = "Value supplied is of wrong type"; break; case ZeissErrorCode.API_E_SET_BAD_PARAMETER: strError = "Parameter supplied is not analogue nor digital"; break; case ZeissErrorCode.API_E_EXEC_TRANSLATE_FAIL: strError = "Failed to translate command into an ID"; break; case ZeissErrorCode.API_E_EXEC_CMD_FAIL: strError = "Failed to execute command"; break; case ZeissErrorCode.API_E_EXEC_MCF_FAIL: strError = "Failed to execute file macro"; break; case ZeissErrorCode.API_E_EXEC_MCL_FAIL: strError = "Failed to execute library macro"; break; case ZeissErrorCode.API_E_EXEC_BAD_COMMAND: strError = "Command supplied is not implemented"; break; case ZeissErrorCode.API_E_GRAB_FAIL: strError = "Grab command failed"; break; case ZeissErrorCode.API_E_GET_STAGE_FAIL: strError = "Get Stage position failed"; break; case ZeissErrorCode.API_E_MOVE_STAGE_FAIL: strError = "Move Stage position failed"; break; case ZeissErrorCode.API_E_NOT_INITIALISED: strError = "API not initialised"; break; case ZeissErrorCode.API_E_NOTIFY_TRANSLATE_FAIL: // 1020L strError = "Failed to translate parameter to an ID"; break; case ZeissErrorCode.API_E_NOTIFY_SET_FAIL: strError = "Set notification failed"; break; case ZeissErrorCode.API_E_GET_LIMITS_FAIL: strError = "Get limits failed"; break; case ZeissErrorCode.API_E_GET_MULTI_FAIL: strError = "Get multiple parameters failed"; break; case ZeissErrorCode.API_E_SET_MULTI_FAIL: strError = "Set multiple parameters failed"; break; case ZeissErrorCode.API_E_NOT_LICENSED: strError = "Missing API license"; break; case ZeissErrorCode.API_E_NOT_IMPLEMENTED: strError = "Reserved or not implemented"; break; case ZeissErrorCode.API_E_GET_USER_NAME_FAIL: strError = "Failed to get user name"; break; case ZeissErrorCode.API_E_GET_USER_IDLE_FAIL: strError = "Failed to get user idle state"; break; case ZeissErrorCode.API_E_GET_LAST_REMOTING_CONNECT_ERROR_FAIL: strError = "Failed to get the last remoting connection error string"; break; case ZeissErrorCode.API_E_EMSERVER_LOGON_FAILED: strError = "Failed to remotely logon to the EM Server. Username and password may be incorrect or EM Server is not running or User is already logged on"; break; case ZeissErrorCode.API_E_EMSERVER_START_FAILED: strError = "Failed to start the EM Server. This may be because the Server is already running or has an internal error."; break; case ZeissErrorCode.API_E_REMOTING_NOT_CONFIGURED: strError = "Remoting incorrectly configured, use RConfigure to correct"; break; case ZeissErrorCode.API_E_REMOTING_FAILED_TO_CONNECT: strError = "Remoting did not connect to the server"; break; case ZeissErrorCode.API_E_REMOTING_COULD_NOT_CREATE_INTERFACE: strError = "Remoting could not start (unknown reason)"; break; case ZeissErrorCode.API_E_REMOTING_EMSERVER_NOT_RUNNING: strError = "EMServer is not running on the remote machine"; break; case ZeissErrorCode.API_E_REMOTING_NO_USER_LOGGED_IN: strError = "No user is logged into EM Server on the remote machine"; break; default: strError = string.Format("Unknown error code {0}", lError); break; } return strError; } #endregion //20201016 扫图速度 #region Focus rate add by sun 2020-12-15 拍截面图调用蔡司接口时,要保证扫描速度5以上,自动亮度对比度功能关闭 public Boolean CmdFocusRate(int mFocusSpeed) { string mTempSpeed = CMD_SCANRATE4; switch (mFocusSpeed) { case 3: mTempSpeed= CMD_SCANRATE3; break; case 4: mTempSpeed = CMD_SCANRATE4; break; case 5: mTempSpeed = CMD_SCANRATE5; break; case 6: mTempSpeed = CMD_SCANRATE6; break; case 7: mTempSpeed = CMD_SCANRATE7; break; case 8: mTempSpeed = CMD_SCANRATE8; break; case 9: mTempSpeed = CMD_SCANRATE9; break; case 10: mTempSpeed = CMD_SCANRATE10; break; default: break; } Boolean ret = ExecuteCmd(mTempSpeed); log.Info("调整扫描速度为====="+ mTempSpeed + "===是否成功"+ ret, true); //CMD_SCANRATE4! return ret; } public Boolean CmdFocusScanSpeed(String mFocusSpeed) { Boolean ret = ExecuteCmd(mFocusSpeed); log.Info("调整扫描速度为 " + mFocusSpeed + " " + ret.ToString(), true); return ret; } #endregion add by sun 2020-12-15 拍截面图调用蔡司接口时,要保证扫描速度5以上,自动亮度对比度功能关闭 end #region Save rate public Boolean CmdSaveRate() { //Boolean ret = ExecuteCmd(CMD_SCANRATE6); //log.Info("CMD_SCANRATE6!", ret); Boolean ret = ExecuteCmd(CMD_SCANRATE7); log.Info("CMD_SCANRATE7!", ret); //Boolean ret = ExecuteCmd(CMD_SCANRATE8); //log.Info("CMD_SCANRATE8!", ret); //Boolean ret = ExecuteCmd(CMD_SCANRATE9); //log.Info("CMD_SCANRATE9!", ret); return ret; } #endregion #region Save best rate public Boolean CmdSaveBestRate() { Boolean ret = ExecuteCmd(CMD_SCANRATE8); log.Info("CMD_SCANRATE8!", ret); return ret; } #endregion #region line scan public Boolean CmdLineScan() { Boolean ret = ExecuteCmd(CMD_LINE_AVG); log.Info("CMD_LINE_AVG!", ret); Thread.Sleep(200); CZEMApi.Set("DP_SCANRATE", new VariantWrapper((float)3)); Thread.Sleep(200); CZEMApi.Set("AP_NR_COEFF", new VariantWrapper((float)30)); Thread.Sleep(200); return ret; } #endregion #region pixel scan public Boolean CmdPixelScan() { Boolean ret = ExecuteCmd(CMD_PIXNR); log.Info("CMD_PIXNR!", ret); Thread.Sleep(200); CZEMApi.Set("DP_SCANRATE", new VariantWrapper((float)3)); Thread.Sleep(200); return ret; } #endregion //20201102 远程服务地址 public void SetRemoteDesELYPath(String path) { this.REMOTEDesELYPATH = path; } public void SetRemoteDesMLFPath(String path) { this.REMOTEDesMLFPATH = path; } public void SetReduced(int x, int y, int W, int H) { CZEMApi.Execute("CMD_MODE_NORMAL"); int X = (int)Math.Floor((double)((1024 - W) / 2.0)); int Y = (int)Math.Floor((double)((768 - H) / 2.0)); CZEMApi.Set("AP_RED_RASTER_W", new VariantWrapper((float)W)); CZEMApi.Set("AP_RED_RASTER_H", new VariantWrapper((float)H)); CZEMApi.Set("AP_RED_RASTER_POSN_X", new VariantWrapper((float)X)); CZEMApi.Set("AP_RED_RASTER_POSN_Y", new VariantWrapper((float)Y)); Thread.Sleep(100); CZEMApi.Execute("CMD_MODE_REDUCED"); Thread.Sleep(100); } public void SetReduced1(int x, int y, int W, int H) { CZEMApi.Execute("CMD_MODE_NORMAL"); CZEMApi.Set("AP_RED_RASTER_W", new VariantWrapper((float)W)); CZEMApi.Set("AP_RED_RASTER_H", new VariantWrapper((float)H)); CZEMApi.Set("AP_RED_RASTER_POSN_X", new VariantWrapper((float)x)); CZEMApi.Set("AP_RED_RASTER_POSN_Y", new VariantWrapper((float)y)); Thread.Sleep(100); CZEMApi.Execute("CMD_MODE_REDUCED"); Thread.Sleep(100); } public void CloseReduced() { CZEMApi.Execute("CMD_MODE_NORMAL"); Thread.Sleep(200); } } }