RfidRailWayNo.cs 3.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135
  1. using System;
  2. using System.IO;
  3. using System.IO.Ports;
  4. using System.Threading;
  5. namespace RailLocalMeter
  6. {
  7. public class RfidRailWayNo
  8. {
  9. Log lg = Log.GetInstance();
  10. SerialPort serialPort1;
  11. bool blThreadFlag = false;
  12. private object obj = new object();
  13. private Thread mThread = null;
  14. /// <summary>
  15. /// comPara是配置文件中的comPara
  16. /// </summary>
  17. /// <param name="comPara"></param>
  18. public void StartThreadSweep(out string msg)
  19. {
  20. #region 串口采集配置
  21. Parity parity = Parity.None;
  22. switch (AppConfigCache.comParity)
  23. {
  24. case "ODD": parity = Parity.Odd; break;
  25. case "EVEN": parity = Parity.Even; break;
  26. default: break;
  27. }
  28. StopBits stopBits = StopBits.None;
  29. switch (AppConfigCache.comStopBits)
  30. {
  31. case "1": stopBits = StopBits.One; break;
  32. case "1.5": stopBits = StopBits.OnePointFive; break;
  33. case "2": stopBits = StopBits.Two; break;
  34. default: break;
  35. }
  36. serialPort1 = new SerialPort(AppConfigCache.comPort, AppConfigCache.comBaud, parity, AppConfigCache.comLength, stopBits);
  37. int icnt = 0;
  38. msg = "";
  39. while (!serialPort1.IsOpen)
  40. {
  41. try
  42. {
  43. icnt++;
  44. serialPort1.Open();
  45. }
  46. catch (Exception err)
  47. {
  48. lg.WriteLog(LogType.RfidLoc, $"打开串口失败,正重试{err.Message}");
  49. }
  50. System.Threading.Thread.Sleep(500);
  51. if (icnt > 5)
  52. {
  53. msg = "串口打开失败,请检查串口是否存在,且是否被占用";
  54. return;
  55. }
  56. }
  57. #endregion
  58. blThreadFlag = true;
  59. mThread = new Thread(new ThreadStart(ThreadSweepInfo));
  60. mThread.Start();
  61. }
  62. /// <summary>
  63. /// 扫码信息读取
  64. /// </summary>
  65. /// <returns></returns>
  66. private void ThreadSweepInfo()
  67. {
  68. try
  69. {
  70. while (blThreadFlag)
  71. {
  72. lock (obj)
  73. {
  74. Thread.Sleep(100);
  75. string strtmp = "";
  76. if (serialPort1.BytesToRead > 0)
  77. {
  78. strtmp = serialPort1.ReadExisting();
  79. }
  80. strtmp = strtmp.Split(new char[] { '\r' })[0];
  81. if (strtmp != "")
  82. {
  83. if (CacleCls.rfidCarNo != strtmp)
  84. {
  85. CacleCls.rfidCarNo = strtmp;
  86. lg.WriteLog(LogType.RfidLoc, $"读卡器读取的数据:{strtmp}");
  87. }
  88. }
  89. }
  90. }
  91. }
  92. catch (Exception exp)
  93. {
  94. lg.WriteLog(LogType.RfidLoc, $"读卡器数据读取异常:{exp.Message}");
  95. }
  96. }
  97. /// <summary>
  98. /// 关闭线程
  99. /// </summary>
  100. /// <returns></returns>
  101. public bool CloseThread()
  102. {
  103. try
  104. {
  105. blThreadFlag = false;
  106. Close();
  107. return true;
  108. }
  109. catch
  110. {
  111. return false;
  112. }
  113. }
  114. /// <summary>
  115. /// 关闭扫描枪
  116. /// </summary>
  117. private void Close()
  118. {
  119. lg.WriteLog(LogType.RfidLoc, $"读卡器关闭");
  120. if (serialPort1 != null && serialPort1.IsOpen) serialPort1.Close();
  121. }
  122. }
  123. }