RfidRailWayNo.cs 4.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152
  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. private byte[] ReadPort(byte[] sendData)
  63. {
  64. serialPort1.Write(sendData, 0, sendData.Length);
  65. DateTime dt = DateTime.Now;
  66. Thread.Sleep(50);
  67. byte[] recData = new byte[serialPort1.BytesToRead];
  68. serialPort1.Read(recData, 0, recData.Length);
  69. return recData;
  70. }
  71. /// <summary>
  72. /// 扫码信息读取
  73. /// </summary>
  74. /// <returns></returns>
  75. private void ThreadSweepInfo()
  76. {
  77. try
  78. {
  79. while (blThreadFlag)
  80. {
  81. lock (obj)
  82. {
  83. byte[] bt = ReadPort(new byte[] { 0x11 });
  84. string strtmp = System.Text.Encoding.UTF8.GetString(bt);
  85. if (!string.IsNullOrEmpty(strtmp))
  86. {
  87. if ((strtmp.IndexOf("T") == 0 || strtmp.IndexOf("Q") == 0 || strtmp.IndexOf("G") == 0) && strtmp.Length > 14)
  88. {
  89. if (CacleCls.rfidCarNo != strtmp && strtmp.Trim() != "")
  90. {
  91. CacleCls.rfidCarNo = strtmp;
  92. lg.WriteLog(LogType.RfidLoc, $"获取并提供给界面的读卡器数据:{strtmp}");
  93. }
  94. }
  95. else
  96. {
  97. lg.WriteLog(LogType.RfidLoc, $"读卡器读取的数据:{strtmp}");
  98. }
  99. }
  100. }
  101. }
  102. }
  103. catch (Exception exp)
  104. {
  105. lg.WriteLog(LogType.RfidLoc, $"读卡器数据读取异常:{exp.Message}");
  106. }
  107. }
  108. /// <summary>
  109. /// 关闭线程
  110. /// </summary>
  111. /// <returns></returns>
  112. public bool CloseThread()
  113. {
  114. try
  115. {
  116. blThreadFlag = false;
  117. Close();
  118. return true;
  119. }
  120. catch
  121. {
  122. return false;
  123. }
  124. }
  125. /// <summary>
  126. /// 关闭扫描枪
  127. /// </summary>
  128. private void Close()
  129. {
  130. lg.WriteLog(LogType.RfidLoc, $"读卡器关闭");
  131. if (serialPort1 != null && serialPort1.IsOpen) serialPort1.Close();
  132. }
  133. }
  134. }