| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244 | using Aitex.Core.RT.Log;using Aitex.Core.RT.SCCore;using Aitex.Core.Util;using System;using System.Collections.Generic;using System.IO.Ports;using System.Linq;using System.Text;using System.Threading;using System.Threading.Tasks;namespace MECF.Framework.Common.Device.BarcodeReader{    public class BarcodeReaderSerialDevice    {        #region Delegate        public delegate void BarcodeReaderDataChanged(string name, string lstContent);        #endregion        #region 常量        private const string CONSTANT_COMMAND = "LON\r";        private const char SPLIT_CHARACTER = '\t';        #endregion        #region 内部变量        /// <summary>        /// 连接状态        /// </summary>        private bool _connected;        /// <summary>        /// 串口        /// </summary>        private SerialPort _serialPort;        /// <summary>        /// 模块名称        /// </summary>        private string _name;        /// <summary>        /// 接收超时        /// </summary>        private int _receiveTimeout = 2000;        /// <summary>        /// 错误信息        /// </summary>        private string _errmsg = "";        /// <summary>        /// 重连        /// </summary>        private bool _reconnected;        /// <summary>        /// 离线时间        /// </summary>        private DateTime _offlineDateTime;        #endregion        #region 公共变量                //发布者 定义事件        public event BarcodeReaderDataChanged OnDataChanged;        #endregion        #region 属性        /// <summary>        /// 连接状态        /// </summary>        public bool Connected        {            get { return _connected; }            set { _connected = value; }        }        #endregion        /// <summary>        /// 构造函数        /// </summary>        /// <param name="name"></param>        /// <param name="portName"></param>        /// <param name="baudRate"></param>        /// <param name="stopBits"></param>        /// <param name="dataBits"></param>        /// <param name="parity"></param>        public BarcodeReaderSerialDevice(string name, string portName, int baudRate = 9600, StopBits stopBits = StopBits.One, int dataBits = 8, Parity parity = Parity.None, bool reconnected = false, int receiveTimeout = 2000)        {            _serialPort = new SerialPort();            _serialPort.BaudRate = baudRate;            _serialPort.StopBits = stopBits;            _serialPort.DataBits = dataBits;            _serialPort.Parity = parity;            _serialPort.PortName = portName;            _serialPort.ErrorReceived += SerialPort_ErrorReceived;            _serialPort.WriteTimeout = receiveTimeout;            _serialPort.ReadTimeout = receiveTimeout;            _receiveTimeout = receiveTimeout;            _name = name;            _reconnected = reconnected;        }        /// <summary>        /// 启动        /// </summary>        public void Start()        {            Open();        }        /// <summary>        /// 打开串口        /// </summary>        private void Open()        {            if (!_connected)            {                try                {                    if (!_serialPort.IsOpen)                    {                        _serialPort.Open();                    }                    _connected = true;                    LOG.WriteLog(eEvent.INFO_BARCODEREADER, _name, $"connect port[{_serialPort.PortName}] success");                }                catch (Exception ex)                {                    WriteErrorMsg(ex.Message);                }            }        }        /// <summary>        /// 关闭        /// </summary>        public void Close()        {            try            {                _connected = false;                _serialPort.Close();            }            catch (Exception ex)            {                WriteErrorMsg(ex.Message);            }        }                #region 事件        /// <summary>        /// 串口错误        /// </summary>        /// <param name="sender"></param>        /// <param name="e"></param>        private void SerialPort_ErrorReceived(object sender, SerialErrorReceivedEventArgs e)        {            LOG.WriteLog(eEvent.ERR_BARCODEREADER, _name, e.EventType.ToString());        }        #endregion        /// <summary>        /// 读取数据        /// </summary>        public string ReadData()        {            try            {                _serialPort.WriteLine(CONSTANT_COMMAND);                DateTime dt = DateTime.Now;                string str = "";                while (DateTime.Now.Subtract(dt).TotalMilliseconds <= _receiveTimeout)                {                    if (_serialPort.BytesToRead > 0)                    {                        string tmp = _serialPort.ReadExisting();                        if (!string.IsNullOrEmpty(tmp))                        {                            str = tmp;                            WriteInfoMsg(0, tmp);                            break;                        }                    }                    else                    {                        Thread.Sleep(100);                    }                }                if (!string.IsNullOrEmpty(str))                {                               if (OnDataChanged != null)                    {                        OnDataChanged(_name, str);                    }                    return str;                }                else                {                    LOG.WriteLog(eEvent.WARN_BARCODEREADER, _name, "No barcode Information received");                    return "";                }            }            catch (Exception ex)            {                WriteErrorMsg(ex.Message);                LOG.WriteLog(eEvent.WARN_BARCODEREADER, _name, "Read barcode failed, Try to Reconnect");                Open();                return "";            }        }        /// <summary>        /// 记录错误信息        /// </summary>        /// <param name="msg"></param>        private void WriteErrorMsg(string msg, bool disConnected = true)        {            if (disConnected)            {                _connected = false;                _offlineDateTime = DateTime.Now;            }            if (_errmsg != msg)            {                _errmsg = msg;                LOG.WriteLog(eEvent.ERR_BARCODEREADER, _name, msg);            }        }        /// <summary>        /// 写日志        /// </summary>        /// <param name="bytes"></param>        private void WriteInfoMsg(int logType, string str)        {            bool enableLog = false;            if (SC.ContainsItem("Log.EnableBarcodeReaderLog"))            {                enableLog = SC.GetValue<bool>("Log.EnableBarcodeReaderLog");            }            if (enableLog)            {                string type = logType == 0 ? "receive" : "send";                LOG.WriteBackgroundLog(eEvent.ERR_BARCODEREADER, _name, $"{type} {str}");            }        }    }}
 |