| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626 | //时间:20200618//作者:郝爽//功能:测量参数using System;using System.Collections.Generic;using System.Linq;using System.Text;using System.Threading.Tasks;using FileManager;using System.Xml;using System.IO;using System.Configuration;namespace MeasureData{    public class MeasureParam : ISlo    {        #region 内容        //工作条件,一次测量的全部切孔都是一类的        // 样品类型        private string m_SampleName;        public string SampleType        {            get { return this.m_SampleName; }            set { this.m_SampleName = value; }        }        public string SampleTypeNo()        {            return m_SampleName.Split('_')[0];//样品类型的命名必须是“0_XXXX" "1_XXXXX"的形式,前面的数字是与谭博士通信的类型指示        }        //是否仅拍照        private Boolean is_Photograph;        public Boolean IsShotSectionToRun        {            get { return this.is_Photograph; }            set { this.is_Photograph = value; }        }               private bool m_IsGetFibPositionToRun;        private  bool m_IsFibCutingToRun;        private bool m_IsMoveToCenterToRun;        private bool m_IsLayerAnalysisToRun;        //是否有pt工序        private Boolean m_pt;        public Boolean IfPT        {            get { return this.m_pt; }            set { this.m_pt = value; }        }        //倾斜样品台        private Boolean m_Tilt;        public Boolean IfTilt        {            get { return this.m_Tilt; }            set { this.m_Tilt = value; }        }        //是否有EDS        private Boolean m_EDS;        public Boolean IsEDSToRun        {            get { return this.m_EDS; }            set { this.m_EDS = value; }        }        //能谱Z轴移动的位置        private float edsZ;        public float EDSZ        {            get { return this.edsZ; }            set { this.edsZ = value; }        }        //能谱电压设定值        private float edsV;        public float EDSV        {            get { return this.edsV; }            set { this.edsV = value; }        }        //能谱电压设定值        private float edsA;        public float EDSA        {            get { return this.edsA; }            set { this.edsA = value; }        }        //Z轴移动的范围        //private float m_dZ;        //public float ZDistance        //{        //    get { return this.m_dZ; }        //    set { this.m_dZ = value; }        //}        //FIB使用的ELY文件        private string m_fibTemp;        public string FIBTemp        {            get { return this.m_fibTemp; }            set { this.m_fibTemp = value; }        }        //PT使用的ELY文件        private string m_ptTemp;        public string PTTemp        {            get { return this.m_ptTemp; }            set { this.m_ptTemp = value; }        }       public string RemoteELYPath ;       public string   RemoteMLFPath;        public string FocusServerIP { get; private set; }        public string FocusServerPort { get; private set; }        public string RemoteCutHoleInfoFilePath { get; private set; }        //拉直操作需要的放大位数        private float straighten_Magnification;        public float Straighten_Magnification        {            get { return this.straighten_Magnification; }            set { this.straighten_Magnification = value; }        }        public bool IsStraightenToRun;        public bool StraightenAutoBC;        public float StraightenManualBrightness;        public float StraightenManualContrast;        //定位切割位置的放大倍数        private float location_Magnification;        public float Location_Magnification        {            get { return this.location_Magnification; }            set { this.location_Magnification = value; }        }        //定位切割位置的工作电压        private float mVoltage;        public float Voltage        {            get { return this.mVoltage; }            set { this.mVoltage = value; }        }        public float Iprobe;        //拍照的放大倍数        private float photograph_Magnification;        public float Photograph_Magnification        {            get { return this.photograph_Magnification; }            set { this.photograph_Magnification = value; }        }        public bool ShotSectionAutoBC;        public float  ShotSectionManualBrightness;        public float ShotSectionManualConstrast;        //拍照的工作电压        private float photograph_Voltage;        public float Photograph_Voltage        {            get { return this.photograph_Voltage; }            set { this.photograph_Voltage = value; }        }                //FIB拍照时的放大倍数        private float fib_Magnification;        public float FIB_Magnification        {            get { return this.fib_Magnification; }            set { this.fib_Magnification = value; }        }        //校正角度选择        private float correction_Angle_Inside;        public float Correction_Angle_Inside        {            get { return this.correction_Angle_Inside; }            set { this.correction_Angle_Inside = value; }        }        private float correction_Angle_OutSide;        public float Correction_Angle_OutSide        {            get { return this.correction_Angle_OutSide; }            set { this.correction_Angle_OutSide = value; }        }        //厂商        private String firm;        public String Firm        {            get { return this.firm; }            set { this.firm = value; }        }                          //EDS参数        private EDSParam EdsParam;        public EDSParam EDSParam        {            get { return this.EdsParam; }            set { this.EdsParam = value; }        }                     //ScanRotation修正角度        private float scanRotCor;        public float ScanRotCor        {            get { return this.scanRotCor; }            set { this.scanRotCor = value; }        }        //ScanRotation修正角度        private float pixelSizeCor;        public float PixelSizeCor        {            get { return this.pixelSizeCor; }            set { this.pixelSizeCor = value; }        }        //能谱参数              //add by sun 2020-12-17 增加调试时是否切割开关        //private bool m_IsCutingForDebug;        //public bool IsCutingForDebug        //{        //    get { return this.m_IsCutingForDebug; }        //    set { this.m_IsCutingForDebug = value; }        //}        //add by sun 2020-12-17 增加调试时是否切割开关 end        //add by zjx 2020-12-18 为了测试只做能谱部分        //private bool m_IsonlyEDSForDebug;        //public bool IsonlyEDSToRun        //{        //    get { return this.m_IsonlyEDSForDebug; }        //    set { this.m_IsonlyEDSForDebug = value; }        //}      private bool m_IsTiltCorrectionToRun;        public bool IsTiltCorrectionToRun { get => m_IsTiltCorrectionToRun; set => m_IsTiltCorrectionToRun = value; }        public bool IsGetFibPositionToRun { get => m_IsGetFibPositionToRun; set => m_IsGetFibPositionToRun = value; }        public bool IsFibCutingToRun { get => m_IsFibCutingToRun; set => m_IsFibCutingToRun = value; }        public bool IsMoveToCenterToRun { get => m_IsMoveToCenterToRun; set => m_IsMoveToCenterToRun = value; }        public int MoveToCenterMagnification { get; private set; }        public bool IsLayerAnalysisToRun { get => m_IsLayerAnalysisToRun; set => m_IsLayerAnalysisToRun = value; }        public bool IsBeamShiftResetToRun { get; private set; }        //add by zjx 2020-12-18 为了测试只做能谱部分 end        #endregion        //构造函数        public MeasureParam()        {            Init();        }        public bool GetMeasureParamFromConfigration()        {            MeasureParam cfm = this;            //设置配置文件默认值            bool bResult = false;            //bool.TryParse(ConfigurationManager.AppSettings["Is_Photograph"].ToString(), out bResult);            //cfm.IsShotSectionToRun = bResult;            bool.TryParse(ConfigurationManager.AppSettings["PT_Depostion"].ToString(), out bResult);            cfm.IfPT = bResult;            cfm.PTTemp = ConfigurationManager.AppSettings["PT_ELYFile"].ToString();            cfm.FIBTemp = ConfigurationManager.AppSettings["FIB_ELYFile"].ToString();            cfm.SampleType = ConfigurationManager.AppSettings["LastSampleType"].ToString();            cfm.Firm = ConfigurationManager.AppSettings["LastSelectFirm"].ToString();            bool.TryParse(ConfigurationManager.AppSettings["Is_Title"].ToString(), out bResult);            cfm.IfTilt = bResult;            bool.TryParse(ConfigurationManager.AppSettings["Is_EDS"].ToString(), out bResult);            cfm.IsEDSToRun = bResult;            cfm.ScanRotCor = Convert.ToSingle(ConfigurationManager.AppSettings["ScanRotCur"].ToString());            cfm.PixelSizeCor = Convert.ToSingle(ConfigurationManager.AppSettings["PixelSize_Y_Cur"].ToString());            cfm.IsEDSToRun = Convert.ToBoolean(ConfigurationManager.AppSettings["Is_EDS"].ToString());            cfm.EDSZ = Convert.ToSingle(ConfigurationManager.AppSettings["EDS_Z"].ToString()) / 1000;            cfm.EDSV = Convert.ToSingle(ConfigurationManager.AppSettings["EDS_V"].ToString());            cfm.EDSA = Convert.ToSingle(ConfigurationManager.AppSettings["EDS_A"].ToString()) / 1000000000;            cfm.EDSParam.XrayCollectMode = Convert.ToInt16(ConfigurationManager.AppSettings["EDS_XrayMode"].ToString());            cfm.RemoteCutHoleInfoFilePath = ConfigurationManager.AppSettings["RemoteCutHoleInfoFilePath"];            cfm.RemoteELYPath = ConfigurationManager.AppSettings["RemoteELYPath"];       cfm.RemoteMLFPath = ConfigurationManager.AppSettings["RemoteMLFPath"];            cfm.FocusServerIP = ConfigurationManager.AppSettings["FocusServerIP"];            cfm.FocusServerPort = ConfigurationManager.AppSettings["FocusServerPort"];            return true;        }        public bool loadParamFromSampleTypeTemplate(string filename)        {            DirectoryInfo TheFolder = new DirectoryInfo(System.Environment.CurrentDirectory + "\\SampleTemplate");            XmlDocument doc = new XmlDocument();            doc.Load(TheFolder+"\\"+filename);//载入xml文件            XmlNode root = doc.SelectSingleNode("XMLData");            xString firm = new xString();                        Slo sFile = new Slo();            sFile.Register("DefaultFirmName", firm);            Slo locateP = new Slo();                       xInt locMag = new xInt();                        locateP.Register("Magnification", locMag);            sFile.Register("Locate", locateP);            Slo votandI = new Slo();                      xInt vot = new xInt();            xDouble iprobe = new xDouble();                      votandI.Register("Votage", vot);            votandI.Register("Iprobe", iprobe);            sFile.Register("VotageAndIprobe", votandI);            Slo tCorrect = new Slo();            xBool tcToRun = new xBool();            xInt Outside = new xInt();            xInt inside = new xInt();            tCorrect.Register("Outside", Outside);            tCorrect.Register("Inside", inside);            tCorrect.Register("ToRun", tcToRun);            sFile.Register("TiltCorrect", tCorrect);            Slo straighten = new Slo();            xInt Straightenmag = new xInt();            xBool torun = new xBool();            xInt b1 = new xInt();            xInt c1 = new xInt();            xBool auto1 = new xBool();            straighten.Register("Magnification", Straightenmag);            straighten.Register("ToRun", torun);            straighten.Register("Hand_Bright", b1);            straighten.Register("Hand_Contrast", c1);            straighten.Register("AutoGet", auto1);            sFile.Register("Straighten", straighten);                             Slo FIBposition = new Slo();            xBool fcrun = new xBool();                      FIBposition.Register("ToRun", fcrun);                      sFile.Register("GetFIBPosition", FIBposition);            Slo fibcuting = new Slo();//fibcross            xBool fibrun = new xBool();            fibcuting.Register("ToRun", fibrun);            sFile.Register("FIBCutting", fibcuting);            Slo movetocenter = new Slo();//findcross            xBool mRun = new xBool();            xInt movemag = new xInt();            movetocenter.Register("ToRun", mRun);            movetocenter.Register("Magnification", movemag);            sFile.Register("MoveToCenter", movetocenter);            Slo shotsection = new Slo();            xBool sRun = new xBool();            xInt shotmag = new xInt();            xBool auto2 = new xBool();            xInt b2 = new xInt();            xInt c2 = new xInt();            shotsection.Register("ToRun", sRun);            shotsection.Register("Magnification", shotmag);            shotsection.Register("Hand_Bright", b2);            shotsection.Register("Hand_Contrast", c2);            shotsection.Register("AutoGet", auto2);            sFile.Register("ShotSection", shotsection);            Slo layerAnalysis = new Slo();            xBool lRun = new xBool();            layerAnalysis.Register("ToRun", lRun);            sFile.Register("LayerAnalysis", layerAnalysis);            //Slo edsAnalysis = new Slo();            //xBool eRun = new xBool();            //edsAnalysis.Register("ToRun", eRun);            //sFile.Register("EDSAnalysis", edsAnalysis);            Slo beamshiftReset = new Slo();            xBool bRun = new xBool();            beamshiftReset.Register("ToRun", bRun);            sFile.Register("BeamShiftReset", beamshiftReset);            sFile.Serialize(false, doc, root);            this.Location_Magnification = locMag.value();            this.mVoltage = vot.value();            this.Iprobe = (float)iprobe.value();            this.IsTiltCorrectionToRun = tcToRun.value();            this.correction_Angle_Inside = inside.value();            this.correction_Angle_OutSide = Outside.value();            this.IsStraightenToRun = torun.value();            this.straighten_Magnification = Straightenmag.value();            this.StraightenAutoBC = auto1.value();            this.StraightenManualBrightness = b1.value();            this.StraightenManualContrast = c1.value();            this.IsGetFibPositionToRun = fcrun.value();                        this.IsFibCutingToRun= fibrun.value();            this.IsMoveToCenterToRun = mRun.value();            this.MoveToCenterMagnification = movemag.value();            this.IsShotSectionToRun = sRun.value();            this.photograph_Magnification = shotmag.value();            this.ShotSectionAutoBC = auto2.value();            this.ShotSectionManualBrightness = b2.value();            this.ShotSectionManualConstrast = c2.value();            this.IsLayerAnalysisToRun = lRun.value();            //this.IsEDSToRun = eRun.value();            this.IsBeamShiftResetToRun = bRun.value();            return true;        }        public void Init()        {            this.SampleType = @"";            this.IfPT = false;            this.FIBTemp = @"";            this.PTTemp = @"";                                  this.IfTilt = false;                       this.IsEDSToRun = false;            this.EDSZ = 0.005f;            this.EDSV = 10000;            this.EDSA = 0.0000000005f;            this.EDSParam = new EDSParam();                        this.ScanRotCor = 1;            this.PixelSizeCor = 1;                      }        //XML文件保存测量参数        public override void Serialize(bool isStoring, XmlDocument xml, XmlNode rootNode)        {            Slo sFile = new Slo();            //是否拍照和PT            xBool isPhotograph = new xBool();            xBool ptDepostion = new xBool();            xBool isTilt = new xBool();            xBool isEDS = new xBool();            isTilt.AssignValue(this.IfTilt);            isEDS.AssignValue(this.IsEDSToRun);            isPhotograph.AssignValue(this.is_Photograph);            ptDepostion.AssignValue(this.m_pt);            sFile.Register("Is_Title", isTilt);            sFile.Register("Is_Photograph", isPhotograph);            sFile.Register("PT_Depostion", ptDepostion);            sFile.Register("Is_EDS", isEDS);            //ELY文件            xString ptELYFile = new xString();            xString fibELYFile = new xString();            ptELYFile.AssignValue(this.m_ptTemp);            fibELYFile.AssignValue(this.m_fibTemp);            sFile.Register("PT_ELYFile", ptELYFile);            sFile.Register("FIB_ELYFile", fibELYFile);            //对焦方式            xInt focusmode = new xInt();                     sFile.Register("FocusMode", focusmode);            //放大倍数和电压参数            xDouble stretchMagnification = new xDouble();            xDouble locationMagnification = new xDouble();            xDouble locationVoltage = new xDouble();            xDouble photographMagnification = new xDouble();            xDouble photographVoltage = new xDouble();            xDouble fibMagnification = new xDouble();            xDouble ZDistance = new xDouble();            xDouble xEDSZ = new xDouble();            xDouble xEDSV = new xDouble();            xDouble xEDSA = new xDouble();            xEDSZ.AssignValue(this.edsZ);            xEDSV.AssignValue(this.edsV);            xEDSA.AssignValue(this.edsA);            //ZDistance.AssignValue(this.ZDistance);            stretchMagnification.AssignValue(this.straighten_Magnification);            locationMagnification.AssignValue(this.location_Magnification);            locationVoltage.AssignValue(this.mVoltage);            photographMagnification.AssignValue(this.photograph_Magnification);            photographVoltage.AssignValue(this.photograph_Voltage);            fibMagnification.AssignValue(this.fib_Magnification);            sFile.Register("Strectch_Magnification", stretchMagnification);            sFile.Register("Locatio_Magnification", locationMagnification);            sFile.Register("Location_Voltage", locationVoltage);            sFile.Register("Photograph_Magnification", photographMagnification);            sFile.Register("Photograph_Voltage", photographVoltage);            sFile.Register("FIB_Magnification", fibMagnification);            //sFile.Register("ZDistance", ZDistance);            sFile.Register("EDSZ", xEDSZ);            sFile.Register("EDSV", xEDSV);            sFile.Register("EDSA", xEDSA);            //校正角度            xDouble correctionAngle = new xDouble();            correctionAngle.AssignValue(this.correction_Angle_Inside);            sFile.Register("Correction_Angle", correctionAngle);            //样品名称和厂商            xString sampleType = new xString();            xString _firm = new xString();            sampleType.AssignValue(this.m_SampleName);            _firm.AssignValue(this.firm);            sFile.Register("Sample_Type", sampleType);            sFile.Register("Firm", _firm);                    sFile.Register("EDS_Param", this.EDSParam);            //ScanRotate修正            xDouble scanRotate = new xDouble();            scanRotate.AssignValue(this.scanRotCor);            sFile.Register("ScanRotateCorrect", scanRotate);            //PixelSize_Y轴补偿            xDouble pscor = new xDouble();            pscor.AssignValue(this.pixelSizeCor);            sFile.Register("PixelSizeYCorrect", pscor);            if (isStoring)            {                sFile.Serialize(true, xml, rootNode);            }            else            {                sFile.Serialize(false, xml, rootNode);                this.is_Photograph = isPhotograph.value();                this.m_pt = ptDepostion.value();                this.IfTilt = isTilt.value();                this.IsEDSToRun = isEDS.value();                this.m_ptTemp = ptELYFile.value();                this.m_fibTemp = fibELYFile.value();                              this.straighten_Magnification = Convert.ToSingle(stretchMagnification.value());                this.location_Magnification = Convert.ToSingle(locationMagnification.value());                this.mVoltage = Convert.ToSingle(locationVoltage.value());                this.photograph_Magnification = Convert.ToSingle(photographMagnification.value());                this.photograph_Voltage = Convert.ToSingle(photographVoltage.value());                this.correction_Angle_Inside  = Convert.ToSingle(correctionAngle.value());                this.m_SampleName = sampleType.value();                this.firm = _firm.value();                //this.ZDistance = Convert.ToSingle(ZDistance.value());                this.EDSZ = Convert.ToSingle(xEDSZ.value());                this.EDSV = Convert.ToSingle(xEDSV.value());                this.EDSA = Convert.ToSingle(xEDSA.value());                this.ScanRotCor = Convert.ToSingle(scanRotate.value());                this.PixelSizeCor = Convert.ToSingle(pscor.value());            }        }    }}
 |