| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251 | using NLog;using SmartSEMControl;using System;using System.Collections.Generic;using System.Linq;using System.Text;using System.Threading;using System.Threading.Tasks;namespace MeasureThread{    class Focus : IFocus    {        private Focusparam prm;        private ISEMControl iSEM;      private  NLog.Logger log;        public Focus( ISEMControl iSEM)        {            log = NLog.LogManager.GetCurrentClassLogger();                       this.iSEM = iSEM ?? throw new ArgumentNullException(nameof(iSEM));            this.log = log ?? throw new ArgumentNullException(nameof(log));        }        public Focusparam GetParam()        {            if (prm == null)            {                prm = new Focusparam();            }            return prm;        }        public bool SetMagnification(float newMag)        {            bool mRetMag = iSEM.SetMagnification(newMag);            //             float set = newMag;            Thread.Sleep(2000);            float current = iSEM.GetMagnification();            Thread.Sleep(200);            while (Math.Abs(current - set) > 1)            {                iSEM.SetMagnification(set);                Thread.Sleep(200);                current = iSEM.GetMagnification();            }            return true;        }        public bool DoFocusByNewMagnification(float newMag)        {            // set magnification            bool mRetMag = iSEM.SetMagnification(newMag);                     //             float set = newMag;            Thread.Sleep(1000);            float current = iSEM.GetMagnification();            Thread.Sleep(200);            while (Math.Abs(current - set) > 1)            {                iSEM.SetMagnification(set);                Thread.Sleep(200);                current = iSEM.GetMagnification();            }            // set the window of focusing.            iSEM.SetReduced(prm.reduceWindowPos.X, prm.reduceWindowPos.Y, (int)prm.reduceWinWidth, (int)prm.reduceWinHeight);            iSEM.CmdFocusScanSpeed("CMD_SCANRATE5");//            if (prm.IfAutoBrightnessAndContrast)            {                iSEM.SetAutoBright(100);                Thread.Sleep(200);                iSEM.SetAutoContrast(100);                Thread.Sleep(200);                iSEM.SetAutoVideoBrightnessAndContrast();                Thread.Sleep(6000);                iSEM.SetAutoVideoOff();            }            else            {                iSEM.SetAutoVideoOff();                Thread.Sleep(200);                iSEM.SetBrightness(prm.brightness);//50.0f                Thread.Sleep(200);                iSEM.SetContrast(prm.contrast);//30.0f                Thread.Sleep(200);            }            bool ifStig=false;            if (newMag > 5000)            {                ifStig = true;            }            if (!ImageFocus1(ifStig))            {                log.Error("自动对焦失败,程序退出。", false);                return false;            }            iSEM.CloseReduced();            Thread.Sleep(200);                    //float cycle_time = iSEM.GetCycleTime();            //Thread.Sleep(1000 + Convert.ToInt32(cycle_time));            return true;        }        public bool DoFocus()        {                           //set voltage and SemIprobe             bool mRet_VoltageFlag = iSEM.SetSEMVoltage(prm.voltage);            Thread.Sleep(500);           bool mRet_ElecFlag = iSEM.SetSEMIPROBE(prm.Iprobe / 1000000000);            Thread.Sleep(500);            // set magnification            bool mRetMag=iSEM.SetMagnification(prm.mag);                        Thread.Sleep(500);            //             if (!TiltCorrection(prm.tiltCorrAngle))            {                               return false;            }             float wd = iSEM.GetWorkingDistance();           float offsetWd = Math.Abs(prm.workingDis - wd*1000);            if (offsetWd > 3)//如果相差3mm以上,则重新设置,否则不动            {                if (!iSEM.SetWorkingDistance(prm.workingDis / 1000))                {                    return false;                }            }                 // set the window of focusing.            iSEM.SetReduced(prm .reduceWindowPos.X, prm.reduceWindowPos.Y, (int)prm.reduceWinWidth, (int)prm .reduceWinHeight);            iSEM.CmdFocusScanSpeed("CMD_SCANRATE5");//            if (prm.IfAutoBrightnessAndContrast)            {                iSEM.SetAutoBright(100);                Thread.Sleep(200);                iSEM.SetAutoContrast(100);                Thread.Sleep(200);                iSEM.SetAutoVideoBrightnessAndContrast();                Thread.Sleep(6000);                iSEM.SetAutoVideoOff();            }            else            {                iSEM.SetAutoVideoOff();                Thread.Sleep(200);                iSEM.SetBrightness(prm.brightness);//50.0f                Thread.Sleep(200);                iSEM.SetContrast(prm.contrast);//30.0f                Thread.Sleep(200);            }            bool ifStig = false;            if (prm.mag > 5000)            {                ifStig = true;            }            else            {                ifStig = prm.ifStig;            }            if (!ImageFocus1(ifStig))            {                log.Error("自动对焦失败,程序退出。", false);                                return false;            }            iSEM.CloseReduced();            Thread.Sleep(200);                      // iSEM.SetAutoVideoBrightnessAndContrast();                      //float cycle_time = iSEM.GetCycleTime();           // Thread.Sleep(1000 + Convert.ToInt32(cycle_time));            return true;        }        public void setFocusParam(Focusparam param)        {            this.prm = param ;                   }        //角度补偿        public bool TiltCorrection(float a_fAngle)        {            if (!iSEM.SetTiltAngleOn())            {                return false;            }            Thread.Sleep(200);            //恢复原始状态            if (!iSEM.SetTiltAngle(a_fAngle))            {                return false;            }            return true;        }        //执行自动对焦        public bool ImageFocus1(Boolean Is_Stig)        {                            #region 执行蔡司自动对焦程序                //服务地址                string snumstr = @"http://192.168.1.101:8123";                bool normalized;                               // 调用方法;只对焦不消像散                if (Is_Stig)                {                    string focusstig = XmlRpcClient.autofocusstig(10, 3, 3, 3, 0.7, snumstr);//,normalized                    if (focusstig != "success")                    {                        return false;                    }                }                else                {                    string onlyfocus = XmlRpcClient.autofocus(10, 3, 3, true, snumstr);//,normalized                    if (onlyfocus != "success")                    {                        return false;                    }                }                #endregion                      return true;        }    }}
 |