| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271 | using System;using Aitex.Core.RT.Device;using Aitex.Core.RT.Log;using Aitex.Core.RT.SCCore;using MECF.Framework.RT.EquipmentLibrary.HardwareUnits.LoadPorts;namespace MECF.Framework.RT.EquipmentLibrary.HardwareUnits.CarrierIdReaders.OmronRFID{    public interface IRFIDMsg    {        string DeviceID { get; set; }        string package(params object[] args);        /// </summary>        /// return value, completed        /// <param name="type"></param>        /// <param name="cmd"></param>        /// <returns></returns>        bool unpackage(string msg);    }    public class handler<T> : IHandler where T : IRFIDMsg, new()    {        public int ID { get; set; }        public int Unit { get; set; }        public bool IsBackground { get; set; }         private static int retry_time = 3;        private int retry_count = retry_time;        private T _imp = new T();                        private object[] _objs = null;        public handler(string deviceID, params object[] objs)        {            _imp.DeviceID = deviceID;            this._objs = objs;        }        public bool Execute<TPort>(ref TPort port) where TPort : ICommunication        {            retry_count = retry_time;            return port.Write(string.Format("{0}\r", _imp.package(this._objs)));        }        /// <summary>        /// return value: bhandle        /// </summary>        /// <typeparam name="TPort"></typeparam>        /// <param name="port"></param>        /// <param name="msg"></param>        /// <param name="completed"></param>        /// <returns></returns>        public bool OnMessage<TPort>(ref TPort port, string message, out bool completed) where TPort : ICommunication        {            completed = false;            try            {                string msg = message.Trim();                string type = msg.Substring(0, 2);                if (!type.Equals("00"))  //0: command failed                {                    /*                    if (retry_count-- <= 0)                    {                        string warning = string.Format("retry over {0} times", retry_time);                        LOG.Warning(warning);                        throw (new ExcuteFailedException(warning));                    }                    */                    string warning = string.Format("excute failed. cause is {0}.", getErrMsg(type));                    //LOG.Warning(warning);                    throw (new ExcuteFailedException(warning));                          //port.Write(string.Format("{0}\r", _imp.package(this._objs)));                    //return true;                }                msg = msg.Substring(2, msg.Length - 2);                completed = _imp.unpackage(msg);                return true;            }            catch (ExcuteFailedException e)            {                throw (e);            }                        catch (Exception ex)            {                LOG.WriteExeption(ex);                throw (new InvalidPackageException(message));            }        }        private string getErrMsg(string error)        {            string msg = "";            switch (error)            {                 case "14":                    msg = "Format error There is a mistake in the command format";                    break;                case "70":                    msg = "Communications error Noise or another hindrance occurs during communications with an ID Tag, and communications cannot be completed normally.";                    break;                case "71":                    msg = "Verification error Correct data cannot be written to an ID Tag";                    break;                case "72":                    msg = "No Tag error Either there is no ID Tag in front of the CIDRW Head, or the CIDRW Head is unable to detect the ID Tag due to environmental factors";                    break;                           case "7B":                    msg = "Outside write area error A write operation was not completed normally because the ID Tag was in an area in which the ID Tag could be read but not written";                    break;               case "7E":                    msg = "ID system error (1) The ID Tag is in a status where it cannot execute command processing";                    break;               case "7F":                    msg = "ID system error (2) An inapplicable ID Tag has been used";                    break;               case "9A":                    msg = "Hardware error in CPU An error occurred when writing to EEPROM.";                    break;            }            return msg;        }    }    public class ReadHandler : IRFIDMsg   //common move    {        public string DeviceID { get; set; }        public ReadHandler()        {        }        public string package(params object[] args)        {            string page = (string)args[0];            return string.Format("{0}{1}", "0100", page);        }        public bool unpackage(string msg)        {            OmronRfidReader device = DEVICE.GetDevice<OmronRfidReader>(DeviceID);            string asciiValue = HEX2ASCII(msg.Substring(0, Math.Min(256, msg.Length))).Trim('\0');            if (asciiValue.IndexOf('\0') != -1)            {                asciiValue = asciiValue.Substring(0, asciiValue.IndexOf('\0'));            }            if (SC.ContainsItem("LoadPort.CarrierIdNeedTrimSpace") &&                SC.GetValue<bool>("LoadPort.CarrierIdNeedTrimSpace"))            {                asciiValue = asciiValue.Trim();            }            device.SetCarrierIdReadResult(asciiValue);            return true;        }        public string HEX2ASCII(string hex)        {            string res = String.Empty;            try            {                for (int a = 0; a < hex.Length; a = a + 2)                {                    string Char2Convert = hex.Substring(a, 2);                    int n = Convert.ToInt32(Char2Convert, 16);                    char c = (char)n;                    res += c.ToString();                }            }            catch (Exception e)            {                LOG.WriteExeption(e);            }            return res;        }    }    public class WriteHandler : IRFIDMsg   //common move    {        public string DeviceID { get; set; }        public string Rfid { get; set; }        public WriteHandler()        {        }        public string package(params object[] args)        {            string page = (string)args[0];            Rfid = (string)args[1];            //Rfid = ASCII2HEX((string)args[1]);            return string.Format("{0}{1}{2}", "0200", page, ASCII2HEX((string)args[1]).ToUpper());        }        public string ASCII2HEX(string src)        {            while (src.Length < 128)            {                src = '\0' + src;            }            if (src.Length > 128)            {                src = src.Substring(0, 128);                //LOG.Write("RFID support max 128 characters");            }            string res = String.Empty;            try            {                char[] charValues = src.ToCharArray();                string hexOutput = "";                foreach (char _eachChar in charValues)                {                    // Get the integral value of the character.                    int value = Convert.ToInt32(_eachChar);                    // Convert the decimal value to a hexadecimal value in string form.                    hexOutput += String.Format("{0:X2}", value);                    // to make output as your eg                     //  hexOutput +=" "+ String.Format("{0:X}", value);                }                return hexOutput;            }            catch (Exception e)            {                LOG.WriteExeption(e);            }            return res;        }        public bool unpackage(string msg)        {            OmronRfidReader device = DEVICE.GetDevice<OmronRfidReader>(DeviceID);            //device.SetCarrierIdWriteResult(Rfid);            return true;        }    }}
 |