| 1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495969798991001011021031041051061071081091101111121131141151161171181191201211221231241251261271281291301311321331341351361371381391401411421431441451461471481491501511521531541551561571581591601611621631641651661671681691701711721731741751761771781791801811821831841851861871881891901911921931941951961971981992002012022032042052062072082092102112122132142152162172182192202212222232242252262272282292302312322332342352362372382392402412422432442452462472482492502512522532542552562572582592602612622632642652662672682692702712722732742752762772782792802812822832842852862872882892902912922932942952962972982993003013023033043053063073083093103113123133143153163173183193203213223233243253263273283293303313323333343353363373383393403413423433443453463473483493503513523533543553563573583593603613623633643653663673683693703713723733743753763773783793803813823833843853863873883893903913923933943953963973983994004014024034044054064074084094104114124134144154164174184194204214224234244254264274284294304314324334344354364374384394404414424434444454464474484494504514524534544554564574584594604614624634644654664674684694704714724734744754764774784794804814824834844854864874884894904914924934944954964974984995005015025035045055065075085095105115125135145155165175185195205215225235245255265275285295305315325335345355365375385395405415425435445455465475485495505515525535545555565575585595605615625635645655665675685695705715725735745755765775785795805815825835845855865875885895905915925935945955965975985996006016026036046056066076086096106116126136146156166176186196206216226236246256266276286296306316326336346356366376386396406416426436446456466476486496506516526536546556566576586596606616626636646656666676686696706716726736746756766776786796806816826836846856866876886896906916926936946956966976986997007017027037047057067077087097107117127137147157167177187197207217227237247257267277287297307317327337347357367377387397407417427437447457467477487497507517527537547557567577587597607617627637647657667677687697707717727737747757767777787797807817827837847857867877887897907917927937947957967977987998008018028038048058068078088098108118128138148158168178188198208218228238248258268278288298308318328338348358368378388398408418428438448458468478488498508518528538548558568578588598608618628638648658668678688698708718728738748758768778788798808818828838848858868878888898908918928938948958968978988999009019029039049059069079089099109119129139149159169179189199209219229239249259269279289299309319329339349359369379389399409419429439449459469479489499509519529539549559569579589599609619629639649659669679689699709719729739749759769779789799809819829839849859869879889899909919929939949959969979989991000100110021003100410051006100710081009101010111012101310141015101610171018101910201021102210231024102510261027102810291030103110321033103410351036103710381039104010411042104310441045104610471048104910501051105210531054105510561057105810591060106110621063106410651066106710681069107010711072107310741075107610771078107910801081108210831084108510861087108810891090109110921093109410951096109710981099110011011102110311041105110611071108110911101111111211131114111511161117111811191120112111221123112411251126112711281129113011311132113311341135113611371138113911401141114211431144114511461147114811491150115111521153115411551156115711581159116011611162116311641165116611671168116911701171117211731174117511761177117811791180118111821183118411851186118711881189119011911192119311941195119611971198119912001201120212031204120512061207120812091210121112121213121412151216121712181219122012211222122312241225122612271228122912301231123212331234123512361237123812391240124112421243124412451246124712481249125012511252125312541255125612571258125912601261126212631264126512661267126812691270127112721273127412751276127712781279128012811282128312841285128612871288128912901291129212931294129512961297129812991300130113021303130413051306130713081309131013111312131313141315131613171318131913201321132213231324132513261327132813291330133113321333133413351336133713381339134013411342134313441345134613471348134913501351135213531354135513561357135813591360136113621363136413651366136713681369137013711372137313741375137613771378137913801381138213831384138513861387138813891390139113921393139413951396139713981399140014011402140314041405140614071408140914101411141214131414141514161417141814191420142114221423142414251426142714281429143014311432143314341435143614371438143914401441144214431444144514461447144814491450145114521453145414551456145714581459146014611462146314641465146614671468146914701471147214731474147514761477147814791480148114821483148414851486148714881489149014911492149314941495149614971498149915001501150215031504150515061507150815091510151115121513151415151516151715181519152015211522152315241525152615271528152915301531153215331534153515361537153815391540154115421543154415451546154715481549155015511552155315541555155615571558155915601561156215631564156515661567156815691570157115721573157415751576157715781579158015811582158315841585158615871588158915901591159215931594159515961597159815991600160116021603160416051606160716081609161016111612161316141615161616171618161916201621162216231624 | //时间://作者://功能:单元测试功能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.Configuration;using System.IO;using SmartSEMControl;using FileManager;using System.Xml;using MeasureData;using WebManager;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;        WebResult wr = new WebResult("127.0.0.1", "18080");        String[] sT;        String[] firms;        Configuration config = ConfigurationManager.OpenExeConfiguration(ConfigurationUserLevel.None);        int pw = 0;        int ph = 0;        int lw = 0;        int lh = 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.SetTiltAngleOn();                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.SetScanRotationOn();                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        #region 读取Xml文件        private void btnReadXml_Click(object sender, EventArgs e)        {            MeasureFile mf = new MeasureFile();            XmlDocument doc = new XmlDocument();            doc.Load("test_opton.msf");//载入xml文件            XmlNode root = doc.SelectSingleNode("XMLData");            mf.Serialize(false, doc, root);            doc.Save("test_opton.msf");        }        #endregion        #region 写入Xml文件        private void btnWriteXml_Click(object sender, EventArgs e)        {            MeasureFile mf = new MeasureFile();            mf.FileName = path + "\\test_opton.msf";            mf.FilePath = path;            CutHole ch = new CutHole();            ch.OPT = Operation.Image;            ch.START = System.DateTime.Now;            ch.END = System.DateTime.Now.AddHours(2);            ch.STATE = State.Success;            ch.SWITCH = true;            SemPosition sp = new SemPosition();            sp.X = 11;            sp.Y = 22;            sp.Z = 33;            sp.T = 44;            sp.R = 55;            sp.M = 66;            ch.Position = sp;            mf.ListCutHole.Add(ch);            ch = new CutHole();            ch.OPT = Operation.Image;            ch.START = System.DateTime.Now;            ch.END = System.DateTime.Now.AddHours(2);            ch.STATE = State.Success;            ch.SWITCH = true;            sp = new SemPosition();            sp.X = 12;            sp.Y = 34;            sp.Z = 56;            sp.T = 78;            sp.R = 90;            sp.M = 55;            ch.Position = sp;            mf.ListCutHole.Add(ch);            MeasureParam md = new MeasureParam();            md.SampleName = "aaaaaa";            md.PT = true;            md.PTTemp = "bbbbb";            md.FIBTemp = "cccc";            md.FocusMode = false;            mf.MParam = md;            mf.New();            //XmlDocument doc = new XmlDocument();            //doc.Load(mf.FilePath+"\\" + mf.FileName);//载入xml文件            //XmlNode root = doc.SelectSingleNode("XMLData");            //mf.Serialize(true, doc, root);            //doc.Save("test.aaa");        }        #endregion        #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.SetAutoVideoContrast();            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.SetAutoVideoBrightnessAndContrast();            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(sfd.FileName);            }        }        #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();        }        private void btnExeEly_Click(object sender, EventArgs e)        {            OpenFileDialog sfd = new OpenFileDialog();            sfd.Title = "选择ELY文件:";            //sfd.InitialDirectory = @"C:\ProgramData\Carl Zeiss\SmartSEM\User\Default";            sfd.Filter = "ELY文件|*.ELY";            if (sfd.ShowDialog() == DialogResult.OK)            {                iSEM.CmdFIBLoadELY(sfd.FileName);            }         }        private void btnExeEly2_Click(object sender, EventArgs e)        {            iSEM.CmdFIBEXPOSUREELY();        }        private void btnFIBStatus_Click(object sender, EventArgs e)        {            btnFIBStatus.Text = iSEM.GetFIBMode().ToString();        }        private void btnPost1_Click(object sender, EventArgs e)        {            double degree = 0;            int direction = 0;            int state = 0;            wr.Img_OffsetAngle_Direction("D:/aaaa.jpg",1,"LG", out degree, out direction, out state);            lbldegree1.Text = degree.ToString("0.0");            lbldirection1.Text = direction.ToString();            lblstate1.Text = state.ToString();        }        private void btnPost2_Click(object sender, EventArgs e)        {            double offsetx = 0;            double offsety = 0;            int state = 0;            wr.Img_Cut_Position("D:/aaaa.jpg", out offsetx, out offsety, out state);            lbllocationx.Text = offsetx.ToString("0.0");            lbllocationy.Text = offsety.ToString("0.0");            lblstate2.Text = state.ToString();        }        private void btnPost3_Click(object sender, EventArgs e)        {            int state = 0;            wr.Img_Cut_Success("D:/aaaa.jpg", "D:/bbbb.jpg", out state);            lblstate3.Text = state.ToString();        }        private void btnPost4_Click(object sender, EventArgs e)        {            double offsetx = 0;            double offsety = 0;            int state = 0;            wr.Img_Trapezoid_Top_Center_Position("D:/aaaa.jpg", out offsetx, out offsety, out state);            lbltopcx.Text = offsetx.ToString("0.0");            lbltopcy.Text = offsety.ToString("0.0");            lblstate4.Text = state.ToString();        }        private void btnPost5_Click(object sender, EventArgs e)        {            List<string> filenames = new List<string>();            filenames.Add("1111111");            filenames.Add("2222222");            filenames.Add("3333333");            lblfocuspath.Text = wr.Img_Auto_Focus(filenames);        }        private void btnPost6_Click(object sender, EventArgs e)        {            List<string> filenames = new List<string>();            filenames.Add("1111111");            filenames.Add("2222222");            filenames.Add("3333333");            lblstigpath.Text = wr.Img_Auto_Focus(filenames);        }        private void btnPost7_Click(object sender, EventArgs e)        {            double offsetx = 0;            double offsety = 0;            double degree = 0;            int direction = 0;            int state = 0;            wr.Img_Center_Position_OffsetAngle_Direction("D:/aaaa.jpg", out offsetx, out offsety, out degree, out direction, out state);            lblcenterx.Text = offsetx.ToString("0.0");            lblcentery.Text = offsety.ToString("0.0");            lbldegree2.Text = degree.ToString();            lbldirection2.Text = direction.ToString();            lblstate5.Text = state.ToString();        }        private void btnPost8_Click(object sender, EventArgs e)        {            int state = 0;            wr.Img_Measure_Size("D:/aaaa.jpg", "1000", "0.005", out state);            lblstate6.Text = state.ToString();        }        private void btnScanRotationSetLock_Click(object sender, EventArgs e)        {            iSEM.SetScanRotationOff();        }        private void button1_Click_1(object sender, EventArgs e)        {            iSEM.SetTiltAngleOff();        }        private void btnTiltAngleSetOn_Click(object sender, EventArgs e)        {            iSEM.SetTiltAngleOn();        }        private void btnScanRotationSetOn_Click(object sender, EventArgs e)        {            iSEM.SetScanRotationOn();        }        private void btnExeEly3_Click(object sender, EventArgs e)        {            iSEM.CmdFIBSTARTELY();        }        private void btnCreateConfig_Click(object sender, EventArgs e)        {            ConfigFile cfm = new ConfigFile();            cfm.Is_Photograph = chkWIsP.Checked;            cfm.PT_Depostion = chkWPT.Checked;            cfm.PT_ELYFile = txtWPTF.Text;            cfm.FIB_ELYFile = txtWFIBF.Text;            cfm.Stretch_Magnification = Convert.ToDouble(cbbWLZ.Text);            cfm.Location_Magnification = Convert.ToDouble(cbbWQGF.Text);            cfm.Location_Voltage = Convert.ToDouble(cbbWQGD.Text);            cfm.Photograph_Magnification = Convert.ToDouble(cbbWPZF.Text);            cfm.Photograph_Voltage = Convert.ToDouble(cbbWPZD.Text);            if(cbbWXZ.SelectedIndex==0)            {                cfm.Correction_Angle = 36.0;            }            else            {                cfm.Correction_Angle = 54.0;            }                        cfm.Sample_Type = cbbWYP.Text;            cfm.Firm = cbbWCS.Text;                        cfm.Save(@"E:\test.cfg");            List<String> _sT = sT.ToList();            if(_sT.IndexOf(cbbWYP.Text)<0)            {                _sT.Add(cbbWYP.Text);                sT = _sT.ToArray();                string wsT = "";                for(int i=0;i<sT.Length;i++)                {                    wsT += sT[i] + ",";                }                wsT = wsT.Substring(0, wsT.Length - 1);                config.AppSettings.Settings["Sample_Type"].Value = wsT;            }            List<String> _firms = firms.ToList();            if (_firms.IndexOf(cbbWCS.Text) < 0)            {                _firms.Add(cbbWCS.Text);                firms = _firms.ToArray();                string wFirms = "";                for (int i = 0; i < firms.Length; i++)                {                    wFirms += firms[i] + ",";                }                wFirms = wFirms.Substring(0, wFirms.Length - 1);                config.AppSettings.Settings["Firm"].Value = wFirms;            }            config.Save(ConfigurationSaveMode.Modified);            ConfigurationManager.RefreshSection("appSettings");//重新加载新的配置文件               reloadconfig();        }        private void btnReadConfig_Click(object sender, EventArgs e)        {            ConfigFile cfm = new ConfigFile();            cfm.Read(@"E:\test.cfg");            chkRIsP.Checked = cfm.Is_Photograph;            chkRPT.Checked = cfm.PT_Depostion;            txtRPTF.Text = cfm.PT_ELYFile;            txtRFIBF.Text = cfm.FIB_ELYFile;            txtRLZ.Text = cfm.Stretch_Magnification.ToString();            txtRQGF.Text = cfm.Location_Magnification.ToString();            txtRQGD.Text = cfm.Location_Voltage.ToString();            txtRPZF.Text = cfm.Photograph_Magnification.ToString();            txtRPZD.Text = cfm.Photograph_Voltage.ToString();            txtRXZ.Text = cfm.Correction_Angle.ToString();            txtRYP.Text = cfm.Sample_Type;            txtRCS.Text = cfm.Firm;        }        private void FormUnitControl_Load(object sender, EventArgs e)        {            reloadconfig();            cbbWYP.SelectedIndex = 0;            cbbWCS.SelectedIndex = 0;            cbbWXZ.SelectedIndex = 0;            this.chart1.Series[0].Points.Clear();                    }        private void reloadconfig()        {            String sample_Type = ConfigurationManager.AppSettings["Sample_Type"];            String firm = ConfigurationManager.AppSettings["Firm"];            sT = sample_Type.Split(',');            cbbWYP.Items.Clear();            for (int i = 0; i < sT.Length; i++)            {                cbbWYP.Items.Add(sT[i]);            }                        firms = firm.Split(',');            cbbWCS.Items.Clear();            for (int i = 0; i < firms.Length; i++)            {                cbbWCS.Items.Add(firms[i]);            }                    }                private void btnPsFile_Click(object sender, EventArgs e)        {            OpenFileDialog sfd = new OpenFileDialog();            sfd.Title = "选择位置文件:";            //sfd.InitialDirectory = @"C:\ProgramData\Carl Zeiss\SmartSEM\User\Default";            sfd.Filter = "TXT文件|*.TXT";            if (sfd.ShowDialog() == DialogResult.OK)            {                //Console.WriteLine(sfd.FileName);                StreamReader sr = new StreamReader(sfd.FileName, Encoding.Default);                String line = "";                sr.ReadLine();                sr.ReadLine();                sr.ReadLine();                sr.ReadLine();                line = sr.ReadLine();                sr.Close();                sr.Dispose();                String[] lines = line.Split(',');                double x = Convert.ToDouble(lines[1]);                double y = Convert.ToDouble(lines[2]);                chart1.Series[0].Points.AddXY(x, y);                chart1.Series[0].Points[0].Label = x.ToString("0.000") + "," + y.ToString("0.000");            }        }        private void btnrect_Click(object sender, EventArgs e)        {            this.chart1.Series[0].Points.Clear();            List<double> xpoints = new List<double>();            List<double> ypoints = new List<double>();            //排列数            int rag = Convert.ToInt32(txtarray.Text);            //间距            double dist = Convert.ToDouble(txtdistance.Text);            //中心点x,y轴坐标            double cx = Convert.ToDouble(txtx.Text);            double cy = Convert.ToDouble(txty.Text);            //求样品1的水平角度            double angle = 0;            //xpoints.Add(Math.Pow(Math.Pow(Convert.ToDouble(txtx.Text), 2) + Math.Pow(Convert.ToDouble(txty.Text), 2), 0.5));            //ypoints.Add(Math.Pow(Math.Pow(Convert.ToDouble(txtx.Text), 2) + Math.Pow(Convert.ToDouble(txty.Text), 2), 0.5));            xpoints.Add(Convert.ToDouble(txtsample1x.Text));            ypoints.Add(Convert.ToDouble(txtsample1y.Text));            //计算第一个点与X轴的交角度数            angle = Math.Atan2(ypoints[0] - cy, cx - xpoints[0]) * 180 / Math.PI;            lblPs1.Text = angle.ToString("0.0");            //这里是求与第一个点横向排列的其他点的移动角度            //就是按45度向左向右移动的度            angle = 45 - angle;            angle = angle * Math.PI / 180;            txtsample1x.Text = xpoints[0].ToString("0.000");            txtsample1y.Text = ypoints[0].ToString("0.000");            chart1.Series[0].Points.AddXY(xpoints[0], ypoints[0]);            chart1.Series[0].Points[chart1.Series[0].Points.Count - 1].Label = xpoints[0].ToString("0.000") + "," + ypoints[0].ToString("0.000");            double tx = 0;            double ty = 0;            for (int j = 0; j < rag; j++)            {                //计算每行第一个点的坐标                if(j>0)                {                    tx = dist * j * Math.Sin(angle);                    ty = dist * j * Math.Cos(angle);                    xpoints.Add(tx + xpoints[0]);                    ypoints.Add(ypoints[0] - ty);                    chart1.Series[0].Points.AddXY(xpoints[xpoints.Count-1], ypoints[ypoints.Count-1]);                    chart1.Series[0].Points[chart1.Series[0].Points.Count - 1].Label = xpoints[xpoints.Count - 1].ToString("0.000") + "," + ypoints[ypoints.Count - 1].ToString("0.000");                }                //计算每行其他点的坐标                for (int i = 1; i < rag; i++)                {                    tx = dist * i * Math.Cos(angle);                    ty = dist * i * Math.Sin(angle);                    xpoints.Add(tx + xpoints[j * rag]);                    ypoints.Add(ty + ypoints[j * rag]);                    chart1.Series[0].Points.AddXY(xpoints[xpoints.Count - 1], ypoints[ypoints.Count - 1]);                    chart1.Series[0].Points[chart1.Series[0].Points.Count - 1].Label = xpoints[xpoints.Count - 1].ToString("0.000") + "," + ypoints[ypoints.Count - 1].ToString("0.000");                }            }        }        private void btn30_Click(object sender, EventArgs e)        {            txtsample1x.Text = "21.7";            txtsample1y.Text = "90";            btnrect_Click(null, null);        }        private void btn45_Click(object sender, EventArgs e)        {            txtsample1x.Text = "29.65";            txtsample1y.Text = "100.35";            btnrect_Click(null, null);        }        private void btn60_Click(object sender, EventArgs e)        {            txtsample1x.Text = "40";            txtsample1y.Text = "108.3";            btnrect_Click(null, null);        }    }}
 |