| 12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394959697989910010110210310410510610710810911011111211311411511611711811912012112212312412512612712812913013113213313413513613713813914014114214314414514614714814915015115215315415515615715815916016116216316416516616716816917017117217317417517617717817918018118218318418518618718818919019119219319419519619719819920020120220320420520620720820921021121221321421521621721821922022122222322422522622722822923023123223323423523623723823924024124224324424524624724824925025125225325425525625725825926026126226326426526626726826927027127227327427527627727827928028128228328428528628728828929029129229329429529629729829930030130230330430530630730830931031131231331431531631731831932032132232332432532632732832933033133233333433533633733833934034134234334434534634734834935035135235335435535635735835936036136236336436536636736836937037137237337437537637737837938038138238338438538638738838939039139239339439539639739839940040140240340440540640740840941041141241341441541641741841942042142242342442542642742842943043143243343443543643743843944044144244344444544644744844945045145245345445545645745845946046146246346446546646746846947047147247347447547647747847948048148248348448548648748848949049149249349449549649749849950050150250350450550650750850951051151251351451551651751851952052152252352452552652752852953053153253353453553653753853954054154254354454554654754854955055155255355455555655755855956056156256356456556656756856957057157257357457557657757857958058158258358458558658758858959059159259359459559659759859960060160260360460560660760860961061161261361461561661761861962062162262362462562662762862963063163263363463563663763863964064164264364464564664764864965065165265365465565665765865966066166266366466566666766866967067167267367467567667767867968068168268368468568668768868969069169269369469569669769869970070170270370470570670770870971071171271371471571671771871972072172272372472572672772872973073173273373473573673773873974074174274374474574674774874975075175275375475575675775875976076176276376476576676776876977077177277377477577677777877978078178278378478578678778878979079179279379479579679779879980080180280380480580680780880981081181281381481581681781881982082182282382482582682782882983083183283383483583683783883984084184284384484584684784884985085185285385485585685785885986086186286386486586686786886987087187287387487587687787887988088188288388488588688788888989089189289389489589689789889990090190290390490590690790890991091191291391491591691791891992092192292392492592692792892993093193293393493593693793893994094194294394494594694794894995095195295395495595695795895996096196296396496596696796896997097197297397497597697797897998098198298398498598698798898999099199299399499599699799899910001001100210031004100510061007100810091010101110121013101410151016101710181019102010211022102310241025102610271028102910301031103210331034103510361037103810391040104110421043104410451046104710481049105010511052105310541055105610571058105910601061106210631064106510661067106810691070107110721073107410751076107710781079108010811082108310841085108610871088108910901091109210931094109510961097109810991100110111021103110411051106110711081109111011111112111311141115111611171118111911201121112211231124112511261127112811291130113111321133113411351136113711381139114011411142114311441145114611471148114911501151115211531154115511561157115811591160116111621163116411651166116711681169117011711172117311741175117611771178117911801181118211831184118511861187118811891190119111921193119411951196119711981199120012011202120312041205120612071208120912101211121212131214121512161217121812191220122112221223122412251226122712281229123012311232 | //时间://作者://功能:单元测试功能using System;using System.Collections.Generic;using System.ComponentModel;using System.Data;using System.Drawing;using System.Linq;using System.Runtime.InteropServices;using System.Text;using System.Threading;using System.Threading.Tasks;using System.Windows.Forms;using System.IO;using SmartSEMControl;using FileManager;using System.Xml;using MeasureData;namespace HOZProject{    public partial class FormUnitControl : Form    {        #region 系统参数        //全局只有一个fatorySEM        static FactoryHardware factorySEM = FactoryHardware.Instance;        ISEMControl iSEM = factorySEM.ISEM;        public XmlManager xmg = new XmlManager();                private String path = Directory.GetCurrentDirectory();        private int st_flag = 0;        #endregion        #region 构造函数        public FormUnitControl()        {            InitializeComponent();            Control.CheckForIllegalCrossThreadCalls = false;            if(iSEM.ConnectStatus())            {                float ret = iSEM.GetFIBIMAGING();                if(ret==0)                {                    btnSEM.BackColor = Color.Lime;                }                else if(ret==1)                {                    btnFIB.BackColor = Color.Lime;                    panelFIB.Visible = true;                }                else if(ret==2)                {                    btnMILL.BackColor = Color.Lime;                }            }            //Calling Notification for updated status            //CZEMApi.Notify += new _EMApiEvents_NotifyEventHandler(CZEMApi_Notify);            //CZEMApi.NotifyWithCurrentValue += new _EMApiEvents_NotifyWithCurrentValueEventHandler(CZEMApi_NotifyWithCurrentValue);            //加载参数        }        #endregion                #region 缩放Get        private void btnenlargeGet_Click(object sender, EventArgs e)        {            float ret = iSEM.GetMagnification();            if (float.IsNaN(ret))            {                txtenlargeSet.Text = "NaN";                txtenlargeSet.Enabled = false;                btnenlargeSet.Enabled = false;            }            else            {                txtenlargeSet.Text = ret.ToString();                btnenlargeSet.Enabled = true;            }        }        #endregion        #region 缩放Set        private void btnenlargeSet_Click(object sender, EventArgs e)        {            float set = 0;            if (float.TryParse(txtenlargeSet.Text, out set))            {                iSEM.SetMagnification(set);            }        }        #endregion        #region 焦距Get        private void btnWDGet_Click(object sender, EventArgs e)        {            float ret = iSEM.GetWorkingDistance();            if (float.IsNaN(ret))            {                txtWDSet.Text = "NaN";                txtWDSet.Enabled = false;                btnWDSet.Enabled = false;            }            else            {                txtWDSet.Text = ret.ToString();                btnWDSet.Enabled = true;            }        }        #endregion        #region 焦距Set        private void btnWDSet_Click(object sender, EventArgs e)        {            float set = 0;            if (float.TryParse(txtWDSet.Text, out set))            {                iSEM.SetWorkingDistance(set);            }        }        #endregion        #region 亮度Get        private void btnBrightnessGet_Click(object sender, EventArgs e)        {            float ret = iSEM.GetBrightness();            if (float.IsNaN(ret))            {                txtBrightnessSet.Text = "NaN";                txtBrightnessSet.Enabled = false;                btnBrightnessSet.Enabled = false;            }            else            {                 txtBrightnessSet.Text = ret.ToString();                btnBrightnessSet.Enabled = true;            }        }        #endregion        #region 亮度Set        private void btnBrightnessSet_Click(object sender, EventArgs e)        {            float set = 0;            if (float.TryParse(txtBrightnessSet.Text, out set))            {                iSEM.SetBrightness(set);            }        }        #endregion        #region 对比度Get        private void btnContrastGet_Click(object sender, EventArgs e)        {            float ret = iSEM.GetContrast();            if (float.IsNaN(ret))            {                txtContrastSet.Text = "NaN";                txtContrastSet.Enabled = false;                btnContrastSet.Enabled = false;            }            else            {                txtContrastSet.Text = ret.ToString();                btnContrastSet.Enabled = true;            }        }        #endregion        #region 对比度Set        private void btnContrastSet_Click(object sender, EventArgs e)        {            float set = 0;            if (float.TryParse(txtContrastSet.Text, out set))            {                iSEM.SetContrast(set);            }        }        #endregion        #region 消像散X Get        private void btnAstigmatismXGet_Click(object sender, EventArgs e)        {            float ret = iSEM.GetAstigmatismX();            if (float.IsNaN(ret))            {                txtAstigmatismXSet.Text = "NaN";                txtAstigmatismXSet.Enabled = false;                btnAstigmatismXSet.Enabled = false;            }            else            {                txtAstigmatismXSet.Text = ret.ToString();                btnAstigmatismXSet.Enabled = true;            }        }        #endregion        #region 消像散X Set        private void btnAstigmatismXSet_Click(object sender, EventArgs e)        {            float set = 0;            if (float.TryParse(txtAstigmatismXSet.Text, out set))            {                iSEM.SetAstigmatismX(set);            }        }        #endregion        #region 消像散Y Get        private void btnAstigmatismYGet_Click(object sender, EventArgs e)        {            float ret = iSEM.GetAstigmatismY();            if (float.IsNaN(ret))            {                txtAstigmatismYSet.Text = "NaN";                txtAstigmatismYSet.Enabled = false;                btnAstigmatismYSet.Enabled = false;            }            else            {                txtAstigmatismYSet.Text = ret.ToString();                btnAstigmatismYSet.Enabled = true;            }        }        #endregion        #region 消像散Y Set        private void btnAstigmatismYSet_Click(object sender, EventArgs e)        {            float set = 0;            if (float.TryParse(txtAstigmatismYSet.Text, out set))            {                iSEM.SetAstigmatismY(set);            }        }        #endregion        #region 角度补偿Get        private void btnTiltAngleGet_Click(object sender, EventArgs e)        {            float ret = iSEM.GetTiltAngle();            if (float.IsNaN(ret))            {                txtTiltAngleSet.Text = "NaN";                txtTiltAngleSet.Enabled = false;                btnTiltAngleSet.Enabled = false;            }            else            {                txtTiltAngleSet.Text = ret.ToString();                btnTiltAngleSet.Enabled = true;            }        }        #endregion        #region 角度补偿Set        private void btnTiltAngleSet_Click(object sender, EventArgs e)        {            float set = 0;            if (float.TryParse(txtTiltAngleSet.Text, out set))            {                iSEM.SetTiltAngle(set);            }        }        #endregion        #region 抓取图像        private void btnGrabImage_Click(object sender, EventArgs e)        {            SaveFileDialog sfd = new SaveFileDialog();            sfd.Title = "图像保存位置:";            sfd.FileName = "test.tif";            sfd.Filter = "TIF文件|*.tif";            if (sfd.ShowDialog() == DialogResult.OK)            {                string fn = sfd.FileName;                iSEM.GrabImage(fn, 0, 0, 1024, 768, 0);            }        }        #endregion        #region ScanRotate Get        private void btnScanRotationGet_Click(object sender, EventArgs e)        {            float ret = iSEM.GetScanRotation();            if (float.IsNaN(ret))            {                txtScanRotationSet.Text = "NaN";                txtScanRotationSet.Enabled = false;                btnScanRotationSet.Enabled = false;            }            else            {                txtScanRotationSet.Text = ret.ToString();                btnScanRotationSet.Enabled = true;            }        }        #endregion        #region ScanRotate Set        private void btnScanRotationSet_Click(object sender, EventArgs e)        {            float set = 0;            if (float.TryParse(txtScanRotationSet.Text, out set))            {                                iSEM.SetScanRotation(set);            }        }        #endregion        #region PixelSize Get        private void btnPixelSizeGet_Click(object sender, EventArgs e)        {            float ret = iSEM.GetPixelSize();            if (float.IsNaN(ret))            {                lblPixelSizeGet.Text = "NaN";            }            else            {                lblPixelSizeGet.Text = ret.ToString();            }        }        #endregion        #region 电子束        private void btnTiltCorrXGet_Click(object sender, EventArgs e)        {            float ret = iSEM.GetBeamShiftX();            if (float.IsNaN(ret))            {                txtTiltCorrX.Text = "NaN";                txtTiltCorrX.Enabled = false;                btnTiltCorrXSet.Enabled = false;            }            else            {                txtTiltCorrX.Text = ret.ToString();                btnTiltCorrXSet.Enabled = true;            }        }        private void btnTiltCorrXSet_Click(object sender, EventArgs e)        {            float set = 0;            if (float.TryParse(txtTiltCorrX.Text, out set))            {                iSEM.SetBeamShiftX(set);            }        }        private void btnTiltCorrYGet_Click(object sender, EventArgs e)        {            float ret = iSEM.GetBeamShiftY();            if (float.IsNaN(ret))            {                txtTiltCorrY.Text = "NaN";                txtTiltCorrY.Enabled = false;                btnTiltCorrYSet.Enabled = false;            }            else            {                txtTiltCorrY.Text = ret.ToString();                btnTiltCorrYSet.Enabled = true;            }        }        private void btnTiltCorrYSet_Click(object sender, EventArgs e)        {            float set = 0;            if (float.TryParse(txtTiltCorrY.Text, out set))            {                iSEM.SetBeamShiftY(set);            }        }        #endregion        #region 开启电压        private void btnOpenVoltage_Click(object sender, EventArgs e)        {            iSEM.CmdOpenVoltage();        }        #endregion        #region 关闭电压        private void btnCloseVoltage_Click(object sender, EventArgs e)        {            iSEM.CmdCloseVoltage();        }        #endregion        #region 电子束校正        private void btnTiltCorr_Click(object sender, EventArgs e)        {            float ret = iSEM.GetTiltCorrection();            if (float.IsNaN(ret))            {                btnTiltCorr.BackColor = Color.Red;            }            else            {                if(ret==0)                {                    btnTiltCorr.BackColor = Color.Blue;                    iSEM.SetTiltCorrectionOn();                    btnTiltCorr.Text = "电子束状态:On";                }                else                {                    btnTiltCorr.BackColor = Color.Lime;                    iSEM.SetTiltCorrectionOff();                    btnTiltCorr.Text = "电子束状态:Off";                }            }        }        #endregion          #region 样品台位置获取        private void btnStageGetX_Click(object sender, EventArgs e)        {            float ret = iSEM.GetStageAtX();            if (float.IsNaN(ret))            {                lblStageX.Text = "NaN";            }            else            {                lblStageX.Text = ret.ToString();            }        }        private void btnStageGetY_Click(object sender, EventArgs e)        {            float ret = iSEM.GetStageAtY();            if (float.IsNaN(ret))            {                lblStageY.Text = "NaN";            }            else            {                lblStageY.Text = ret.ToString();            }        }        private void btnStageGetZ_Click(object sender, EventArgs e)        {            float ret = iSEM.GetStageAtZ();            if (float.IsNaN(ret))            {                lblStageZ.Text = "NaN";            }            else            {                lblStageZ.Text = ret.ToString();            }        }        private void btnStageGetT_Click(object sender, EventArgs e)        {            float ret = iSEM.GetStageAtT();            if (float.IsNaN(ret))            {                lblStageT.Text = "NaN";            }            else            {                lblStageT.Text = ret.ToString();            }        }        private void btnStageGetR_Click(object sender, EventArgs e)        {            float ret = iSEM.GetStageAtR();            if (float.IsNaN(ret))            {                lblStageR.Text = "NaN";            }            else            {                lblStageR.Text = ret.ToString();            }        }        private void btnStageGetM_Click(object sender, EventArgs e)        {            float ret = iSEM.GetStageAtM();            if (float.IsNaN(ret))            {                lblStageM.Text = "NaN";            }            else            {                lblStageM.Text = ret.ToString();            }        }        #endregion        #region 样品台位置设置        private void btnStageSetX_Click(object sender, EventArgs e)        {            float set = 0;            if (float.TryParse(txtStageX.Text, out set))            {                iSEM.SetStageGotoX(set);            }        }        private void btnStageSetY_Click(object sender, EventArgs e)        {            float set = 0;            if (float.TryParse(txtStageY.Text, out set))            {                iSEM.SetStageGotoY(set);            }        }        private void btnStageSetZ_Click(object sender, EventArgs e)        {            float set = 0;            if (float.TryParse(txtStageZ.Text, out set))            {                iSEM.SetStageGotoZ(set);            }        }        private void btnStageSetT_Click(object sender, EventArgs e)        {            float set = 0;            if (float.TryParse(txtStageT.Text, out set))            {                iSEM.SetStageGotoT(set);            }        }        private void btnStageSetR_Click(object sender, EventArgs e)        {            float set = 0;            if (float.TryParse(txtStageR.Text, out set))            {                iSEM.SetStageGotoR(set);            }        }        private void btnStageSetM_Click(object sender, EventArgs e)        {            float set = 0;            if (float.TryParse(txtStageM.Text, out set))            {                iSEM.SetStageGotoM(set);            }        }        #endregion        #region 获取样品台位置数组        private void btnGetStagePosition_Click(object sender, EventArgs e)        {            float[] pt = iSEM.GetStagePosition();            if (!float.IsNaN(pt[0]))            {                lblStageX.Text = pt[0].ToString();            }            if (!float.IsNaN(pt[1]))            {                lblStageY.Text = pt[1].ToString();            }            if (!float.IsNaN(pt[2]))            {                lblStageZ.Text = pt[2].ToString();            }            if (!float.IsNaN(pt[3]))            {                lblStageT.Text = pt[3].ToString();            }            if (!float.IsNaN(pt[4]))            {                lblStageR.Text = pt[4].ToString();            }            if (!float.IsNaN(pt[5]))            {                lblStageM.Text = pt[5].ToString();            }        }        #endregion        #region 窗体关闭        private void FormUnitControl_FormClosing(object sender, FormClosingEventArgs e)        {            if(iSEM!=null)            {                iSEM.Dispose();            }        }        #endregion        #region 宏文件        private void btnCMDMCF_Click(object sender, EventArgs e)        {            iSEM.CMDMCFFilename("OPTON");        }        #endregion        private void btnCreatXml_Click(object sender, EventArgs e)        {            SaveFileDialog sfd = new SaveFileDialog();            sfd.Title = "生成Xml文件位置:";            sfd.FileName = "test.xml";            sfd.Filter = "XML文件|*.xml";            if (sfd.ShowDialog() == DialogResult.OK)            {                string fn = sfd.FileName;                List<KeyValuePair<String, String>> lkvp = new List<KeyValuePair<string, string>>();                lkvp.Add(new KeyValuePair<string, string>("key1","value1"));                lkvp.Add(new KeyValuePair<string, string>("key2", "value2"));                xmg.CreateXmlFile(fn,"XMLData");                lkvp.Clear();                lkvp.Add(new KeyValuePair<string, string>("key3", "value3"));                lkvp.Add(new KeyValuePair<string, string>("key4", "value4"));                //xmg.CreateNode(fn, "XMLData", "子节点", "", lkvp);                //xmg.CreateNode(fn, "子节点", "子bb节点", "", lkvp);            }        }        private void button1_Click_1(object sender, EventArgs e)        {            XmlDocument doc = new XmlDocument();            doc.Load("test.xml");//载入xml文件            XmlNode root = doc.SelectSingleNode("XMLData");            MeasureFile mf = new MeasureFile();            mf.FileName = "New FileName";            mf.FilePath = "D:\\opton\\New FilePath";            CutHole ch = new CutHole();            ch.SampleName = "SampleName1";            ch.PT = true;            ch.FIBTemp = "FIBTemp1";            ch.PTTemp = "PTTemp1";            ch.OPT = MeasureData.Operation.Image;            ch.START = System.DateTime.Now;            ch.END = System.DateTime.Now.AddHours(2);            ch.STATE = MeasureData.State.Success;            ch.SWITCH = true;            mf.ListCutHole.Add(ch);            mf.Serialize(true, doc, root);            doc.Save("test.xml");        }        #region SEM模式        private void btnSEM_Click(object sender, EventArgs e)        {            if(iSEM.CmdFIBModeSEM())            {                btnFIB.BackColor = SystemColors.Control;                btnSEM.BackColor = Color.Lime;                btnMILL.BackColor = SystemColors.Control;                panelFIB.Visible = false;            }         }        #endregion        #region FIB模式        private void btnFIB_Click(object sender, EventArgs e)        {            if(iSEM.CmdFIBModeFIB())            {                btnFIB.BackColor = Color.Lime;                btnSEM.BackColor = SystemColors.Control;                btnMILL.BackColor = SystemColors.Control;                panelFIB.Visible = true;            }        }        #endregion        #region MILL模式        private void btnMILL_Click(object sender, EventArgs e)        {            if(iSEM.CmdFIBModeMILL())            {                btnFIB.BackColor = SystemColors.Control;                btnSEM.BackColor = SystemColors.Control;                btnMILL.BackColor = Color.Lime;            }        }        #endregion        #region 自动对焦1        private void btnAutoFocus1_Click(object sender, EventArgs e)        {            //抓图1            iSEM.GrabImage(path + "\\test1.tif", 0, 0, 1024, 768, 0);            if (File.Exists(path + "\\test1.tif"))            {                FileStream fileStream = new FileStream(path + "\\test1.tif", FileMode.Open, FileAccess.Read);                pictureBox1.Image = Image.FromStream(fileStream);                fileStream.Close();                fileStream.Dispose();            }            Thread.Sleep(1000);            iSEM.CmdAutoFocusCoarse();            btnAutoFocus1.BackColor = Color.Red;            st_flag = 1;            Thread.Sleep(1000);            Thread thread = new Thread(AutoFunction);            thread.Start();        }        #endregion        #region 自动函数监测线程        private void AutoFunction()        {            float ret = 111;            Boolean state = false;            while(true)            {                //Thread.Sleep(1000);                ret = iSEM.GetAutoFunction();                if(ret==0)                {                    if (st_flag == 1 && state == true)                    {                        btnAutoFocus1.BackColor = Color.Lime;                        Thread.Sleep(1000);                        //抓图1                        iSEM.GrabImage(path + "\\test2.tif", 0, 0, 1024, 768, 0);                        if (File.Exists(path + "\\test2.tif"))                        {                            FileStream fileStream = new FileStream(path + "\\test2.tif", FileMode.Open, FileAccess.Read);                            pictureBox2.Image = Image.FromStream(fileStream);                            fileStream.Close();                            fileStream.Dispose();                        }                        break;                    }                    else if(st_flag==2 && state)                    {                        btnAutoFocus2.BackColor = Color.Lime;                        Thread.Sleep(1000);                        //抓图1                        iSEM.GrabImage(path + "\\test2.tif", 0, 0, 1024, 768, 0);                        if (File.Exists(path + "\\test2.tif"))                        {                            FileStream fileStream = new FileStream(path + "\\test2.tif", FileMode.Open, FileAccess.Read);                            pictureBox2.Image = Image.FromStream(fileStream);                            fileStream.Close();                            fileStream.Dispose();                        }                        break;                    }                    else if (st_flag == 3)                    {                        btnAutoBrightness.BackColor = Color.Lime;                        Thread.Sleep(1000);                        //抓图1                        iSEM.GrabImage(path + "\\test2.tif", 0, 0, 1024, 768, 0);                        if (File.Exists(path + "\\test2.tif"))                        {                            FileStream fileStream = new FileStream(path + "\\test2.tif", FileMode.Open, FileAccess.Read);                            pictureBox2.Image = Image.FromStream(fileStream);                            fileStream.Close();                            fileStream.Dispose();                        }                        break;                    }                    else if (st_flag == 4)                    {                        btnAutoContrast.BackColor = Color.Lime;                        Thread.Sleep(1000);                        //抓图1                        iSEM.GrabImage(path + "\\test2.tif", 0, 0, 1024, 768, 0);                        if (File.Exists(path + "\\test2.tif"))                        {                            FileStream fileStream = new FileStream(path + "\\test2.tif", FileMode.Open, FileAccess.Read);                            pictureBox2.Image = Image.FromStream(fileStream);                            fileStream.Close();                            fileStream.Dispose();                        }                        break;                    }                    else if (st_flag == 5)                    {                        btnAutoBrightness.BackColor = Color.Lime;                        btnAutoContrast.BackColor = Color.Lime;                        btnAutoBC.BackColor = Color.Lime;                        Thread.Sleep(1000);                        //抓图1                        iSEM.GrabImage(path + "\\test2.tif", 0, 0, 1024, 768, 0);                        if (File.Exists(path + "\\test2.tif"))                        {                            FileStream fileStream = new FileStream(path + "\\test2.tif", FileMode.Open, FileAccess.Read);                            pictureBox2.Image = Image.FromStream(fileStream);                            fileStream.Close();                            fileStream.Dispose();                        }                        break;                    }                    else if (st_flag == 6 && state)                    {                        btnAutoBCCancle.BackColor = Color.Lime;                        Thread.Sleep(1000);                        //抓图1                        iSEM.GrabImage(path + "\\test2.tif", 0, 0, 1024, 768, 0);                        if (File.Exists(path + "\\test2.tif"))                        {                            FileStream fileStream = new FileStream(path + "\\test2.tif", FileMode.Open, FileAccess.Read);                            pictureBox2.Image = Image.FromStream(fileStream);                            fileStream.Close();                            fileStream.Dispose();                        }                        break;                    }                    else if (st_flag == 7 && state)                    {                        btnAutoStig.BackColor = Color.Lime;                        Thread.Sleep(1000);                        //抓图1                        iSEM.GrabImage(path + "\\test2.tif", 0, 0, 1024, 768, 0);                        if (File.Exists(path + "\\test2.tif"))                        {                            FileStream fileStream = new FileStream(path + "\\test2.tif", FileMode.Open, FileAccess.Read);                            pictureBox2.Image = Image.FromStream(fileStream);                            fileStream.Close();                            fileStream.Dispose();                        }                        break;                    }                    ////抓图1                    //iSEM.GrabImage(path + "\\test2.tif", 0, 0, 1024, 768, 0);                    //if (File.Exists(path + "\\test2.tif"))                    //{                    //    FileStream fileStream = new FileStream(path + "\\test2.tif", FileMode.Open, FileAccess.Read);                    //    pictureBox2.Image = Image.FromStream(fileStream);                    //    fileStream.Close();                    //    fileStream.Dispose();                    //}                                    }                else if(ret>0 && ret<12)                {                    state = true;                }            }        }        #endregion        #region 自动对焦2        private void btnAutoFocus2_Click(object sender, EventArgs e)        {            //抓图1            iSEM.GrabImage(path + "\\test1.tif", 0, 0, 1024, 768, 0);            if (File.Exists(path + "\\test1.tif"))            {                FileStream fileStream = new FileStream(path + "\\test1.tif", FileMode.Open, FileAccess.Read);                pictureBox1.Image = Image.FromStream(fileStream);                fileStream.Close();                fileStream.Dispose();            }            Thread.Sleep(1000);            iSEM.CmdAutoFocusFine();            btnAutoFocus2.BackColor = Color.Red;            st_flag = 2;            Thread.Sleep(1000);            Thread thread = new Thread(AutoFunction);            thread.Start();        }        #endregion        #region 自动亮度、对比度        private void btnAutoBrightness_Click(object sender, EventArgs e)        {            //抓图1            iSEM.GrabImage(path + "\\test1.tif", 0, 0, 1024, 768, 0);            if (File.Exists(path + "\\test1.tif"))            {                FileStream fileStream = new FileStream(path + "\\test1.tif", FileMode.Open, FileAccess.Read);                pictureBox1.Image = Image.FromStream(fileStream);                fileStream.Close();                fileStream.Dispose();            }            Thread.Sleep(1000);            iSEM.SetAutoVideoBrightness();            btnAutoBrightness.BackColor = Color.Red;            st_flag = 3;            Thread.Sleep(1000);            Thread thread = new Thread(AutoFunction);            thread.Start();        }        private void btnAutoContrast_Click(object sender, EventArgs e)        {            //抓图1            iSEM.GrabImage(path + "\\test1.tif", 0, 0, 1024, 768, 0);            if (File.Exists(path + "\\test1.tif"))            {                FileStream fileStream = new FileStream(path + "\\test1.tif", FileMode.Open, FileAccess.Read);                pictureBox1.Image = Image.FromStream(fileStream);                fileStream.Close();                fileStream.Dispose();            }            Thread.Sleep(1000);            iSEM.SetAutoVideoBrightness();            btnAutoContrast.BackColor = Color.Red;            st_flag = 4;            Thread.Sleep(1000);            Thread thread = new Thread(AutoFunction);            thread.Start();        }        private void btnAutoBC_Click(object sender, EventArgs e)        {            //抓图1            iSEM.GrabImage(path + "\\test1.tif", 0, 0, 1024, 768, 0);            if (File.Exists(path + "\\test1.tif"))            {                FileStream fileStream = new FileStream(path + "\\test1.tif", FileMode.Open, FileAccess.Read);                pictureBox1.Image = Image.FromStream(fileStream);                fileStream.Close();                fileStream.Dispose();            }            Thread.Sleep(1000);            iSEM.SetAutoVideoBrightness();            btnAutoBrightness.BackColor = Color.Red;            btnAutoContrast.BackColor = Color.Red;            btnAutoBC.BackColor = Color.Red;            st_flag = 5;            Thread.Sleep(1000);            Thread thread = new Thread(AutoFunction);            thread.Start();        }        private void btnAutoBCCancle_Click(object sender, EventArgs e)        {            iSEM.SetAutoVideoOff();            btnAutoBCCancle.BackColor = Color.Red;            st_flag = 6;            Thread.Sleep(1000);            Thread thread = new Thread(AutoFunction);            thread.Start();        }        #endregion        #region 自动消像散        private void btnAutoStig_Click(object sender, EventArgs e)        {            //抓图1            iSEM.GrabImage(path + "\\test1.tif", 0, 0, 1024, 768, 0);            if (File.Exists(path + "\\test1.tif"))            {                FileStream fileStream = new FileStream(path + "\\test1.tif", FileMode.Open, FileAccess.Read);                pictureBox1.Image = Image.FromStream(fileStream);                fileStream.Close();                fileStream.Dispose();            }            Thread.Sleep(1000);            iSEM.CmdAutoStig();            btnAutoStig.BackColor = Color.Red;            st_flag = 7;            Thread.Sleep(1000);            Thread thread = new Thread(AutoFunction);            thread.Start();        }        #endregion        #region FIB缩放Get        private void btnFIBMagGet_Click(object sender, EventArgs e)        {            float ret = iSEM.GetFIBMagnification();            if (float.IsNaN(ret))            {                txtFIBMag.Text = "NaN";                txtFIBMag.Enabled = false;                btnFIBMagSet.Enabled = false;            }            else            {                txtFIBMag.Text = ret.ToString();                btnFIBMagSet.Enabled = true;            }        }        #endregion        #region FIB缩放Set        private void btnFIBMagSet_Click(object sender, EventArgs e)        {            float set = 0;            if (float.TryParse(txtFIBMag.Text, out set))            {                iSEM.SetFIBMagnification(set);            }        }        #endregion        #region FIB焦距Get        private void btnFIBWDGet_Click(object sender, EventArgs e)        {            float ret = iSEM.GetFIBObjectivePotential();            if (float.IsNaN(ret))            {                txtFIBWD.Text = "NaN";                txtFIBWD.Enabled = false;                btnFIBWDSet.Enabled = false;            }            else            {                txtFIBWD.Text = ret.ToString();                btnFIBWDSet.Enabled = true;            }        }        #endregion        #region FIB焦距Set        private void btnFIBWDSet_Click(object sender, EventArgs e)        {            float set = 0;            if (float.TryParse(txtFIBWD.Text, out set))            {                iSEM.SetFIBObjectivePotential(set);            }        }        #endregion        #region FIB电子束移动        private void btnFIBBeamShiftXGet_Click(object sender, EventArgs e)        {            float ret = iSEM.GetFIBBeamShiftX();            if (float.IsNaN(ret))            {                txtFIBBeamShiftX.Text = "NaN";                txtFIBBeamShiftX.Enabled = false;                btnFIBBeamShiftXSet.Enabled = false;            }            else            {                txtFIBBeamShiftX.Text = ret.ToString();                btnFIBBeamShiftXSet.Enabled = true;            }        }        private void btnFIBBeamShiftXSet_Click(object sender, EventArgs e)        {            float set = 0;            if (float.TryParse(txtFIBBeamShiftX.Text, out set))            {                iSEM.SetFIBBeamShiftX(set);            }        }        private void btnFIBBeamShiftYGet_Click(object sender, EventArgs e)        {            float ret = iSEM.GetFIBBeamShiftY();            if (float.IsNaN(ret))            {                txtFIBBeamShiftY.Text = "NaN";                txtFIBBeamShiftY.Enabled = false;                btnFIBBeamShiftYSet.Enabled = false;            }            else            {                txtFIBBeamShiftY.Text = ret.ToString();                btnFIBBeamShiftYSet.Enabled = true;            }        }        private void btnFIBBeamShiftYSet_Click(object sender, EventArgs e)        {            float set = 0;            if (float.TryParse(txtFIBBeamShiftY.Text, out set))            {                iSEM.SetFIBBeamShiftY(set);            }        }        #endregion        #region 执行宏文件        private void btnMCF_Click(object sender, EventArgs e)        {            OpenFileDialog sfd = new OpenFileDialog();            sfd.Title = "选择宏文件:";            sfd.InitialDirectory = @"C:\ProgramData\Carl Zeiss\SmartSEM\User\Default";            sfd.Filter = "MLF文件|*.MLF";            if (sfd.ShowDialog() == DialogResult.OK)            {                string fn = Path.GetFileNameWithoutExtension(sfd.FileName).ToUpper();                iSEM.CMDMCFFilename(fn);                            }        }        #endregion        #region FIB消像散        private void btnFIBAstigmatismXGet_Click(object sender, EventArgs e)        {            float ret = iSEM.GetFIBAstigmatismX();            if (float.IsNaN(ret))            {                txtFIBAstigmatismX.Text = "NaN";                txtFIBAstigmatismX.Enabled = false;                btnFIBAstigmatismXSet.Enabled = false;            }            else            {                txtFIBAstigmatismX.Text = ret.ToString();                btnFIBAstigmatismXSet.Enabled = true;            }        }        private void btnFIBAstigmatismXSet_Click(object sender, EventArgs e)        {            float set = 0;            if (float.TryParse(txtFIBAstigmatismX.Text, out set))            {                iSEM.SetFIBAstigmatismX(set);            }        }        private void btnFIBAstigmatismYGet_Click(object sender, EventArgs e)        {            float ret = iSEM.GetFIBAstigmatismY();            if (float.IsNaN(ret))            {                txtFIBAstigmatismY.Text = "NaN";                txtFIBAstigmatismY.Enabled = false;                btnFIBAstigmatismYSet.Enabled = false;            }            else            {                txtFIBAstigmatismY.Text = ret.ToString();                btnFIBAstigmatismYSet.Enabled = true;            }        }        private void btnFIBAstigmatismYSet_Click(object sender, EventArgs e)        {            float set = 0;            if (float.TryParse(txtFIBAstigmatismY.Text, out set))            {                iSEM.SetFIBAstigmatismY(set);            }        }        #endregion        #region 移动样品台XY        private void btnMoveXY_Click(object sender, EventArgs e)        {            float setx = 0;            float sety = 0;            if (!float.TryParse(txtStageX.Text, out setx))            {                return;            }            if(!float.TryParse(txtStageY.Text,out sety))            {                return;            }            btnMoveXY.BackColor = Color.Red;            iSEM.MoveStageXY(setx, sety);            Thread.Sleep(500);            Thread th = new Thread(MoveStagexy);            th.Start();        }        private void MoveStagexy()        {            float ret = 111;            while(true)            {                ret = iSEM.GetStageIs();                if(ret==0)                {                    btnMoveXY.BackColor = Color.Lime;                    break;                }            }        }        #endregion        #region 获取分辨率        private void btnImageStoreGet_Click(object sender, EventArgs e)        {            int[] ret = iSEM.GetImageStore();            lblImageStore.Text = ret[0].ToString() + "*" + ret[1].ToString();        }        #endregion        #region 设置分辨率        private void btnImageStoreSet_Click(object sender, EventArgs e)        {            if (cmbImageStore.SelectedIndex > -1 && cmbImageStore.SelectedIndex < 12)            {                iSEM.SetImageStore(cmbImageStore.SelectedIndex);            }        }        #endregion        #region 样品台急停        private void btnAbort_Click(object sender, EventArgs e)        {            iSEM.CmdStageAbort();        }        #endregion        private void btnLive_Click(object sender, EventArgs e)        {            iSEM.ImageLive();        }        private void btnFrozen_Click(object sender, EventArgs e)        {            iSEM.ImageFrozen();        }    }}
 |