| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532 | using Aitex.Common.Util;using Aitex.Core.Common;using Aitex.Core.RT.Event;using Aitex.Core.RT.Log;using Aitex.Core.RT.SCCore;using MECF.Framework.Common.Communications;using MECF.Framework.Common.Equipment;using MECF.Framework.Common.SubstrateTrackings;using MECF.Framework.RT.EquipmentLibrary.HardwareUnits.OcrReaders;using System;using System.Collections.Generic;using System.IO;using System.Linq;using System.Text;using System.Text.RegularExpressions;using System.Threading.Tasks;namespace MECF.Framework.RT.EquipmentLibrary.HardwareUnits.OcrReaders.IOSS{    public class IossWidReader: OCRReaderBaseDevice, IConnection    {        public IossWidReader(string module,string name,string scRoot):base(module,name)        {            _scRoot = scRoot;            InitIoss();            CheckToPostMessage((int)OCRReaderMsg.StartInit, null);        }        private void InitIoss()        {            JobFileList = new List<string>();            lib = new Wid110Lib();            _enableLog = SC.GetValue<bool>($"{_scRoot}.{Name}.EnableLogMessage");            if (!isValidIP(Address))            {                EV.PostAlarmLog("System", $"Invalid IP address for WIDReader:{Name}");                return;            }            if (!lib.FInit(Address))            {                EV.PostAlarmLog("System", $"WIDReader:{Name} initialize failed");                int eno = Wid110LibConst.ecNotInit;                eno = lib.FGetLastError();                if (lib.isException())                    LOG.Write("getLastError(): EXCEPTION\r\n" + lib.getLastExcp());                LOG.Write("getLastError(): return " + eno);                return;            }            var fileInfo = new FileInfo(PathManager.GetDirectory($"Logs\\{Name}"));            if (fileInfo.Directory != null && !fileInfo.Directory.Exists)                fileInfo.Directory.Create();            if (fileInfo.Directory != null)                _imageStorePath = fileInfo.FullName;            EV.PostInfoLog("System", $"WIDReader:{Name} initialize successful");            IsConnected = true;        }        private string _imageStorePath;        private bool isValidIP(string ip)        {            char[] sep = { '.' };            string[] adr = ip.Split(sep);            try            {                return (isValidIPPart(Convert.ToInt32(adr[0]))                         && isValidIPPart(Convert.ToInt32(adr[1]))                         && isValidIPPart(Convert.ToInt32(adr[2]))                         && isValidIPPart(Convert.ToInt32(adr[3])));            }            catch (Exception e)            {                LOG.Write("isValidIP( " + ip + " )\r\n"                      + "ERROR: Invalid IP Address\r\n"                      + e.ToString());                return false;            }        }               private bool isValidIPPart(int adr)        {            return (adr >= 0 && adr <= 255);        }        private Wid110Lib lib;        private string _scRoot;        public string Address => SC.GetStringValue($"{_scRoot}.{Name}.Address");        private bool _enableLog;        public bool IsConnected { get; set; }        private bool _isNeedSavePicture        {            get            {                if (SC.ContainsItem($"{_scRoot}.{Name}.SavePicture"))                    return SC.GetValue<bool>($"{_scRoot}.{Name}.SavePicture");                return false;            }        }        protected override bool fStartSavePicture(object[] param)        {            return true;        }        protected override bool fMonitorSavingPicture(object[] param)        {            IsBusy = false;            GetProcessImage();            return true;        }        protected override bool fStartReset(object[] param)        {            IsBusy = false;            _enableLog = SC.GetValue<bool>($"{_scRoot}.{Name}.EnableLogMessage");            if (!isValidIP(Address))            {                EV.PostAlarmLog("System", $"Invalid IP address for WIDReader:{Name}");                return false;            }                       if (!lib.FInit(Address))            {                EV.PostAlarmLog("System", $"WIDReader:{Name} initialize address:{Address} failed");                int eno = Wid110LibConst.ecNotInit;                eno = lib.FGetLastError();                if (lib.isException())                    LOG.Write("getLastError(): EXCEPTION\r\n" + lib.getLastExcp());                LOG.Write("getLastError(): return " + eno);                return false;            }            EV.PostInfoLog("System", $"WIDReader:{Name} initialize successful");            IsConnected = true;            return true; ;        }        protected override bool fStartInit(object[] param)        {            IsBusy = false;            return true;        }        protected override bool fMonitorInit(object[] param)        {            IsBusy = false;            return true;        }        protected override bool fStartSetParameter(object[] param)        {            return true ;        }        private string m_readparameter;        protected override bool fStartReadParameter(object[] param)        {            m_readparameter = param[0].ToString();            switch (m_readparameter)            {                case "JobList":                    if (SC.ContainsItem($"{ _scRoot}.{ Name}.DirectoryForJob") && !string.IsNullOrEmpty(SC.GetStringValue($"{ _scRoot}.{ Name}.DirectoryForJob")))                    {                        string jobpath = SC.GetStringValue($"{ _scRoot}.{ Name}.DirectoryForJob");                        string[] files = Directory.GetFiles(jobpath);                        JobFileList = new List<string>();                        JobFileList.Clear();                        foreach (string strfile in files)                        {                            FileInfo f = new FileInfo(strfile);                            if (f.Extension == ".job")                            {                                JobFileList.Add(f.Name);                            }                        }                    }                                       break;                default:                    break;            }            return true; ;        }        protected override bool fMonitorReadParameter(object[] param)        {            IsBusy = false;            return true;        }        protected override bool fStartReadWaferID(object[] param)        {            //string job = param[0].ToString();            //int lasermarkindex = (int)param[1];            //IsReadLaserMark1 = lasermarkindex == 0;            //string path = SC.GetStringValue($"{ _scRoot}.{ Name}.DirectoryForJob");                    //if(!lib.FLoadRecipes(path + "\\" + job))            //{            //    string le = lib.FGetErrorDescription(lib.FGetLastError());            //    OnError("Load job failed:"+le);                            //    return false;            //}            //if (!lib.FProcessRead())            //{            //    string le = lib.FGetErrorDescription(lib.FGetLastError());            //    OnError("Read laser mark failed:" +le);            //    return false;            //}            return true;            //return lib.FGetWaferId();        }        protected override bool fMonitorReading(object[] param)        {            IsBusy = false;            string job = CurrentParamter[0].ToString();            int lasermarkindex = (int)CurrentParamter[1];            IsReadLaserMark1 = lasermarkindex == 0;            string path = SC.GetStringValue($"{ _scRoot}.{ Name}.DirectoryForJob");            if(!lib.FLoadRecipes(path + "\\" + job))            {                if (!lib.FInit(Address))                {                    EV.PostAlarmLog("System", $"WIDReader:{Name} initialize address:{Address} failed");                    int eno = Wid110LibConst.ecNotInit;                    eno = lib.FGetLastError();                    if (lib.isException())                        LOG.Write("getLastError(): EXCEPTION\r\n" + lib.getLastExcp());                    LOG.Write("getLastError(): return " + eno);                    string le = lib.FGetErrorDescription(lib.FGetLastError());                    OnError("Load job failed:" + le);                    ReadOK = false;                    return false;                }                else if(!lib.FLoadRecipes(path + "\\" + job))                {                    string le = lib.FGetErrorDescription(lib.FGetLastError());                    OnError("Load job failed:" + le);                    ReadOK = false;                    return false;                }            }            if (!lib.FProcessRead())            {                string le = lib.FGetErrorDescription(lib.FGetLastError());                OnError("Read laser mark failed:" + le);                ReadOK = false;                return false;            }            ReadOK = true;            CurrentLaserMark = lib.FGetWaferId().Replace("READ:","").Trim();            if(CurrentLaserMark.Length > KeepLaserMarkCharatersNumber)            {                CurrentLaserMark = CurrentLaserMark.Substring(0, KeepLaserMarkCharatersNumber);            }            CurrentLaserMarkScore = Convert.ToSingle(lib.FGetCodeQualityOCR());            if (IsReadLaserMark1)            {                LaserMark1 = CurrentLaserMark;                LaserMark1Score = CurrentLaserMarkScore.ToString();                LaserMark1ReadTime = lib.FGetCodeTime().ToString();                LaserMark1ReadResult = $"ID:{LaserMark1},Score:{LaserMark1Score},Read time:{LaserMark1ReadTime}";            }            else            {                LaserMark2 = CurrentLaserMark;                LaserMark2Score = CurrentLaserMarkScore.ToString();                LaserMark2ReadTime = lib.FGetCodeTime().ToString();                LaserMark2ReadResult = $"ID:{LaserMark2},Score:{LaserMark2Score},Read time:{LaserMark2ReadTime}";            }            if(_isNeedSavePicture)            {                GetProcessImage();            }                        IsBusy = false;            return true;        }        private void GetProcessImage(int bestOrAll=0)        {            try            {                if (!lib.FIsInitialized())                {                    string errMsg;                    if (lib.CheckError(out errMsg))                    {                        OnError("ERROR: " + errMsg);                    }                    return;                }                if (!lib.FProcessGetImage(CurrentImageFileName, bestOrAll))                {                    if (lib.getErrno() == Wid110LibConst.ecNoMoreImg)                    {                        EV.PostInfoLog("WIDReader", "No images retrieved after last process trigger.");                    }                    string errMsg;                    if (lib.CheckError(out errMsg))                    {                        EV.PostWarningLog(Name, "ERROR: " + errMsg);                    }                }                else                {                    if (CurrentLaserMarkScore < ScoreThresholdToSaveImage)                    {                        if(SavePictureOption == PictureOptionEnum.All || SavePictureOption == PictureOptionEnum.Failed)                            SaveCurrentImageToFailedImage();                    }                    else                    {                        if (SavePictureOption == PictureOptionEnum.All || SavePictureOption == PictureOptionEnum.Success)                            SaveCurrentImage();                    }                                    }                DeleteEarlyImageFile(PicturesQuanlityLimit);            }            catch(Exception ex)            {                LOG.Write(ex);            }        }        private string _currentWaferID => WaferManager.Instance.GetWafer(InstalledModule, 0).WaferID ?? "";                     public override string[] GetJobFileList()        {            return JobFileList.ToArray();        }        public bool Connect()        {            return true;        }        public bool Disconnect()        {            return true;        }        public override void Terminate()        {            try            {                if (!lib.FExit())                {                    LOG.Write(lib.FGetErrorDescription(lib.FGetLastError()));                }            }            catch(Exception ex)            {                LOG.Write(ex);            }                    }        private bool SaveCurrentImageToFailedImage(string wid = "")        {            try            {                string waferID = WaferManager.Instance.GetWaferID(ModuleName.Aligner, 0) ?? "";                if (wid != "") waferID = wid;                if (File.Exists(CurrentImageFileName))                {                    string[] temps = CurrentImageFileName.Split('\\');                    string pathname = CurrentImageFileName.Replace(temps.LastOrDefault(), "") + "FailedPictures\\"                        + DateTime.Now.ToString("yyyy-MM-dd");                    if (!Directory.Exists(pathname))                    {                        Directory.CreateDirectory(pathname);                    }                    string failedImage = pathname + "\\" + "Failed_" + waferID + "_" + string.Format("{0:yyyyMMddHHmmss}", DateTime.Now) + ".bmp";                    File.Copy(CurrentImageFileName, failedImage, true);                    LOG.Write($"Read success image file for {waferID} was save as {failedImage}.");                }                return true;            }            catch (Exception ex)            {                LOG.Write(ex);                return false;            }        }        private bool SaveCurrentImage(string wid = "")        {            try            {                string waferID = WaferManager.Instance.GetWaferID(ModuleName.Aligner, 0) ?? "";                if (wid != "") waferID = wid;                if (File.Exists(CurrentImageFileName))                {                    string[] temps = CurrentImageFileName.Split('\\');                    string pathname = CurrentImageFileName.Replace(temps.LastOrDefault(), "") + "SuccessPictures\\"                         + DateTime.Now.ToString("yyyy-MM-dd");                    if (!Directory.Exists(pathname))                    {                        Directory.CreateDirectory(pathname);                    }                    string successimage = pathname + "\\" + "Success_" +                        waferID + "_" + string.Format("{0:yyyyMMddHHmmss}", DateTime.Now) + ".bmp";                    File.Copy(CurrentImageFileName, successimage, true);                    LOG.Write($"Read success image file for {waferID} was save as {successimage}.");                    return true;                }                return true;            }            catch (Exception ex)            {                LOG.Write(ex);                return false;            }        }        private void DeleteEarlyImageFile(int fileCount)        {            try            {                string[] temps = CurrentImageFileName.Split('\\');                string imagepath = CurrentImageFileName.Replace("\\" + temps.LastOrDefault(), "");                if (string.IsNullOrEmpty(imagepath)) return;                string[] fpath = Directory.GetFiles(imagepath, "*.bmp", SearchOption.AllDirectories);                Dictionary<string, DateTime> fCreateDate = new Dictionary<string, DateTime>();                for (int i = 0; i < fpath.Length; i++)                {                    FileInfo fi = new FileInfo(fpath[i]);                    fCreateDate[fpath[i]] = fi.CreationTime;                }                fCreateDate = fCreateDate.OrderBy(f => f.Value).ToDictionary(f => f.Key, f => f.Value);                int fCount = fCreateDate.Count;                while (fCount > fileCount)                {                    string strFile = fCreateDate.First().Key;                    if (strFile == CurrentImageFileName)                    {                        fCreateDate.Remove(strFile);                        fCount = fCreateDate.Count;                        continue;                    }                    File.Delete(strFile);                    fCreateDate.Remove(strFile);                    fCount = fCreateDate.Count;                    LOG.Write($"Success to delete file:{strFile}");                }                DeleteEmptyDirectory(imagepath);                LOG.Write($"Complete to delete file");            }            catch (Exception ex)            {            }        }        public static void DeleteEmptyDirectory(String storagepath)        {            DirectoryInfo dir = new DirectoryInfo(storagepath);            DirectoryInfo[] subdirs = dir.GetDirectories("*.*", SearchOption.AllDirectories);            foreach (DirectoryInfo subdir in subdirs)            {                FileSystemInfo[] subFiles = subdir.GetFileSystemInfos();                if (subFiles.Count() == 0)                {                    subdir.Delete();                }            }        }    }}
 |