Usf500NConnection.cs 3.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119
  1. using System;
  2. using System.Collections.Generic;
  3. using System.Linq;
  4. using System.Text;
  5. using System.Threading.Tasks;
  6. using MECF.Framework.Common.Communications;
  7. namespace MECF.Framework.RT.EquipmentLibrary.HardwareUnits.FlowMeters
  8. {
  9. public class Usf500NMessage : BinaryMessage
  10. {
  11. public byte Address { get; set; }
  12. public byte FunctionCode { get; set; }
  13. public byte ReadOutByteNumber { get; set; }
  14. public byte[] RegisterAddress { get; set; }
  15. public byte[] WriteData { get; set; }
  16. public byte[] ReadOutData { get; set; }
  17. }
  18. public class Usf500NConnection : SerialPortConnectionBase
  19. {
  20. private List<byte> _lstCacheBuffer = new List<byte>();
  21. public Usf500NConnection(string portName) : base(portName,9600,8, System.IO.Ports.Parity.None, System.IO.Ports.StopBits.One,"\r",false)
  22. {
  23. }
  24. public override bool SendMessage(byte[] message)
  25. {
  26. _lstCacheBuffer.Clear();
  27. return base.SendMessage(message);
  28. }
  29. protected override MessageBase ParseResponse(byte[] rawMessage)
  30. {
  31. _lstCacheBuffer.AddRange(rawMessage);
  32. byte[] temps = _lstCacheBuffer.ToArray();
  33. Usf500NMessage msg = new Usf500NMessage();
  34. msg.IsResponse = false;
  35. msg.IsAck = false;
  36. msg.IsComplete = false;
  37. msg.RawMessage = _lstCacheBuffer.ToArray();
  38. if (temps.Length < 6) return msg;
  39. msg.FunctionCode = rawMessage[1];
  40. if (msg.FunctionCode == 3 || msg.FunctionCode == 4)
  41. {
  42. msg.ReadOutByteNumber = temps[2];
  43. if (temps.Length < 5 + msg.ReadOutByteNumber)
  44. return msg;
  45. msg.ReadOutData = temps.Skip(3).Take(msg.ReadOutByteNumber*2).ToArray();
  46. }
  47. if (temps.LastOrDefault() != Calculate_CRC(temps.Take(temps.Length - 2).ToArray())[1]
  48. || temps[temps.Length - 2] != Calculate_CRC(temps.Take(temps.Length - 2).ToArray())[0])
  49. return msg;
  50. msg.Address = temps[0];
  51. msg.FunctionCode = temps[1];
  52. if (msg.FunctionCode == 6)
  53. {
  54. msg.RegisterAddress = temps.Skip(2).Take(2).ToArray();
  55. msg.WriteData = temps.Skip(4).Take(2).ToArray();
  56. }
  57. msg.IsResponse = true;
  58. msg.IsAck = true;
  59. msg.IsComplete = true;
  60. return msg;
  61. }
  62. protected override void ActiveHandlerProceedMessage(MessageBase msg)
  63. {
  64. base.ActiveHandlerProceedMessage(msg);
  65. }
  66. private static byte[] Calculate_CRC(byte[] buffer)
  67. {
  68. ushort X = 0xFFFF;
  69. for (int i = 0; i < buffer.Length; i++)
  70. {
  71. int timeNo = 0;
  72. while (timeNo < 9)
  73. {
  74. timeNo++;
  75. X = (ushort)(X ^ buffer[i]);
  76. ushort tempValue = (ushort)(X & 1);
  77. X = (ushort)(X >> 1);
  78. if (tempValue == 1)
  79. {
  80. X = (ushort)(X ^ 0xA001);
  81. }
  82. }
  83. }
  84. return new byte[] {(byte)(X>>8), (byte)(X &0xFF) };
  85. }
  86. }
  87. }