Udostępnij za pośrednictwem


SerialPort Encoding [Ryan Byington]

The SerialPort class uses the encoding specified by the SerialPort.Encoding property to convert strings and character arrays to bytes to send across the serial port. This encoding also gets used when reading from the serial port to convert bytes received by the serial port to strings and character arrays. <?xml:namespace prefix = o ns = "urn:schemas-microsoft-com:office:office" />

By default the SerialPort class uses ASCII encoding which converts all characters with the value of 0-127 to a single byte with the same value. So “Hello” gets converted to the byte array {72, 101, 108, 108, 111}. However every other character gets converted to a byte with the value of 63 or the ‘?’ character. This applies for reading as well so if the serial port received the byte array {72, 101, 108, 108, 111} it will convert this to “Hello” and any byte with a value greater then 127 will get converted to the ‘?’ character.

 

The ASCII encoding works perfectly fine for most serial devices but there are still quite a few device that either send bytes with values beyond 127 or you need to send bytes with values greater then 127. You have two options; one would be to use the API’s that deal with byte[] and bypass the Encoding, or to use the correct Encoding. However finding the correct encoding is a bit tricky as most encodings that deal with values above 127 will use multiple bytes which probably won’t work with the device attached to the serial port. The only encoding that converts all characters with a value 0-255 to a single byte with the corresponding value and vice versa when converting bytes to characters is the “Western European (ISO)” encoding. Use the following code to use this Encoding with the SerialPort class:

 

            SerialPort mySerialPort = new SerialPort(“COM1”);

            mySerialPort.Encoding = Encoding.GetEncoding(28591);

Comments

  • Anonymous
    May 26, 2006
    Over on the BCLTeam's WebLog, Ryan Byington wrote a mostly excellent post entitled SerialPort Encoding....
  • Anonymous
    May 26, 2006
    On the other hand, if you meant to say that 28591 (ISO Western Europe, 8859-1) is the one encoding that maps 0xNN to 0x00NN and back, that is midly true (though not very relevant to any device that expects a particular encoding) and it ignores best fit fallbacks (and this code page has 302 of those, which would lead to data corruption if they were hit!)....
  • Anonymous
    May 29, 2006
    Is it just me, or is the code snippet woefully incomplete? It seems to stop immediately after "mySerialPort.Encoding = Encoding.GetEncoding".
  • Anonymous
    May 30, 2006
    The sample should have been:
    SerialPort mySerialPort = new SerialPort(“COM1”);
    mySerialPort.Encoding = Encoding.GetEncoding(28591);

    Thanks for pointing this out.
  • Anonymous
    October 10, 2006
    The SerialPort class requires some “warming up” time for our users coming from VB6 or other non-.NET
  • Anonymous
    January 21, 2009
    PingBack from http://www.hilpers.it/2624296-invio-sms-con-vb