2015-07-13 79 views
2

我正在使用串口应用程序发送带有Unicode控制字符的命令,但没有成功。当我在hyperterminal或Putty中发送相同的命令时,通信起作用,所以我很好奇这两个程序是否写出一个字节或Unicode字符数组,甚至是一个字符串。如果我模仿他们做什么,我可能会成功......另外我注意到,我从Visual Studio中的工具箱中取出的串口属性列为使用我在代码中写入的不同COM端口,这就是为什么我没有得到任何回应,或者我的代码覆盖了吗?在进行环回测试时,我得到了正确命令的输出以及控制字符,所以我无法弄清楚我做错了什么。这是.NET 2.0 Framework FYISerialPorts:以字节或字符发送?

using System; 
using System.Collections.Generic; 
using System.ComponentModel; 
using System.Data; 
using System.Drawing; 
using System.Text; 
using System.Windows.Forms; 
using System.IO.Ports; 
using System.Threading; 

namespace SimpleSerial 
{ 
    public partial class Form1 : Form 
    { 
     string RxString; 
     public Form1() 
     { 
      InitializeComponent(); 
     } 
     private void buttonStart_Click(object sender, EventArgs e) 
     { 
      serialPort1.PortName = "COM3"; 
      serialPort1.BaudRate = 9600; 
      serialPort1.Parity = Parity.None; 
      serialPort1.DataBits = 8; 
      serialPort1.StopBits = StopBits.One; 
      serialPort1.Handshake = Handshake.None; 
      serialPort1.ReadTimeout = 500; 
      serialPort1.WriteTimeout = 500; 
      serialPort1.Open(); 
      if (serialPort1.IsOpen) 
      { 
       buttonStart.Enabled = false; 
       buttonStop.Enabled = true; 
       textBox1.ReadOnly = false; 
      } 
     } 
     const char STX = '\u0002'; 
     const char ETX = '\u0003'; 
     readonly string pull_shelf_104 = string.Format("{0}01P00104##{1}" , STX, ETX); 
     private byte[] WrapString(string pull_shelf_104) 
     { 
      return System.Text.Encoding.ASCII.GetBytes(pull_shelf_104); 
     } 
     private void linkLabel_HC1_100_LinkClicked(object sender, LinkLabelLinkClickedEventArgs e) 
     { 
      if (serialPort1.IsOpen) 
      { 
       byte[] data = WrapString(pull_shelf_104); 
       serialPort1.Write(data, 0, data.Length); 
      } 
     } 
     private void buttonStop_Click(object sender, EventArgs e) 
     { 
      if (serialPort1.IsOpen) 
      { 
       serialPort1.Close(); 
       buttonStart.Enabled = true; 
       buttonStop.Enabled = false; 
       textBox1.ReadOnly = true; 
      } 
     } 
     private void Form1_FormClosing(object sender, FormClosingEventArgs e) 
     { 
      if (serialPort1.IsOpen) serialPort1.Close(); 
     } 
     private void DisplayText(object sender, EventArgs e) 
     { 
      textBox1.AppendText(RxString); 
     } 
     private void serialPort1_DataReceived(object sender, System.IO.Ports.SerialDataReceivedEventArgs e) 
     { 
      RxString = serialPort1.ReadExisting(); 
      this.Invoke(new EventHandler(DisplayText)); 
     } 
    } 
} 
+0

您打开通讯端口发送/接收字节。这些字节是什么(它们是否在某种编码等等)取决于它们。腻子以终端模式(?)工作,所以它希望从调制解调器接收ASCII字符。关于com-ports,哦,大惊喜,它们可以是不同PC上的任何东西,意味着你不应该编写“com3”''。您可以在设备管理器中更改com端口名称,但这不会消除com端口识别问题。 – Sinatr

+0

'byte [] ackData = Encoding.ASCII.GetBytes(string here);'试试这个将starings转换为原始字节。 – hypheni

+0

您正在关注错误的问题。没有很多使用Handshake.None的串口设备。当你使用它时,你需要将RtsEnable和DtrEnable属性设置为* true *。如果你不这样做,那么设备不会发送任何东西。 –

回答

0

上面的评论帮我解决了这个问题,谢谢你的帮助!我需要在我的代码中启用RTS和DTS,列出COM端口不是问题,虽然我确定它在某些情况下。这是我的代码,用于任何有类似问题的人。

using System; 
using System.Collections.Generic; 
using System.ComponentModel; 
using System.Data; 
using System.Drawing; 
using System.Text; 
using System.Windows.Forms; 
using System.IO.Ports; 
using System.Threading; 

namespace SimpleSerial 
{ 
    public partial class Form1 : Form 
    { 
     string RxString; 
     public Form1() 
     { 
      InitializeComponent(); 
     } 
     private void buttonStart_Click(object sender, EventArgs e) 
     { 
      serialPort1.PortName = "COM3"; 
      serialPort1.BaudRate = 9600; 
      serialPort1.Parity = Parity.None; 
      serialPort1.DataBits = 8; 
      serialPort1.StopBits = StopBits.One; 
      serialPort1.Handshake = Handshake.None; 
      serialPort1.RtsEnable = true; 
      serialPort1.DtrEnable = true; 
      serialPort1.ReadTimeout = 2000; 
      serialPort1.WriteTimeout = 2000; 
      serialPort1.Open(); 
      if (serialPort1.IsOpen) 
      { 
       buttonStart.Enabled = false; 
       buttonStop.Enabled = true; 
       textBox1.ReadOnly = false; 
      } 
     } 
     const char STX = '\u0002'; 
     const char ETX = '\u0003'; 
     readonly string pull_shelf_104 = string.Format("{0}01P00204##{1}" , STX, ETX); 
     private byte[] WrapString(string pull_shelf_104) 
     { 
      return System.Text.Encoding.ASCII.GetBytes(pull_shelf_104); 
     } 
     private void linkLabel_HC1_100_LinkClicked(object sender, LinkLabelLinkClickedEventArgs e) 
     { 
      if (serialPort1.IsOpen) 
      { 
       byte[] data = WrapString(pull_shelf_104); 
       serialPort1.Write(data, 0, data.Length); 
      } 
     } 
     private void buttonStop_Click(object sender, EventArgs e) 
     { 
      if (serialPort1.IsOpen) 
      { 
       serialPort1.Close(); 
       buttonStart.Enabled = true; 
       buttonStop.Enabled = false; 
       textBox1.ReadOnly = true; 
      } 
     } 
     private void Form1_FormClosing(object sender, FormClosingEventArgs e) 
     { 
      if (serialPort1.IsOpen) serialPort1.Close(); 
     } 
     private void DisplayText(object sender, EventArgs e) 
     { 
      textBox1.AppendText(RxString); 
     } 
     private void serialPort1_DataReceived(object sender, System.IO.Ports.SerialDataReceivedEventArgs e) 
     { 
      RxString = serialPort1.ReadExisting(); 
      this.Invoke(new EventHandler(DisplayText)); 
     } 
    } 
}