Chinaunix首页 | 论坛 | 博客
  • 博客访问: 8346918
  • 博文数量: 1413
  • 博客积分: 11128
  • 博客等级: 上将
  • 技术积分: 14685
  • 用 户 组: 普通用户
  • 注册时间: 2006-03-13 10:03
个人简介

follow my heart...

文章分类

全部博文(1413)

文章存档

2013年(1)

2012年(5)

2011年(45)

2010年(176)

2009年(148)

2008年(190)

2007年(293)

2006年(555)

分类:

2006-11-01 09:12:33

[点评:这几天一直用这个控件,可是老是有问题,也许这篇文章是解决问题最终的办法了.]
SerialPort中串口数据的读取与写入有较大的不同。由于串口不知道数据何时到达,因此有两种方法可以实现串口数据的读取。

    一、线程实时读串口;

    二、事件触发方式实现。

     由于线程实时读串口的效率不是十分高效,因此比较好的方法是事件触发的方式。在SerialPort类中有DataReceived事件,当串口的读缓存 有数据到达时则触发DataReceived事件,其中SerialPort.ReceivedBytesThreshold属性决定了当串口读缓存中数 据多少个时才触发DataReceived事件,默认为1。

    另外,SerialPort.DataReceived事件运行比较特殊,其运行在辅线程,不能与主线程中的显示数据控件直接进行数据传输,必须用间接的方式实现。如下:

SerialPort spSend; //spSend,spReceive用虚拟串口连接,它们之间可以相互传输数据。spSend发送数据 SerialPort spReceive; //spReceive接受数据 TextBox txtSend; //发送区 TextBox txtReceive; //接受区 Button btnSend; //数据发送按钮 delegate void HandleInterfaceUpdateDelegate(string text); //委托,此为重点 HandleInterfaceUpdateDelegate interfaceUpdateHandle;

public void InitClient() //窗体控件已在初始化 {
interfaceUpdateHandle
= new HandleInterfaceUpdateDelegate(UpdateTextBox); //实例化委托对象 spSend.Open(); //SerialPort对象在程序结束前必须关闭,在此说明 spReceive.DataReceived += Ports.SerialDataReceivedEventHandler(spReceive_DataReceived);
spReceive.ReceivedBytesThreshold
= 1;
spReceive.Open();
}

public void btnSend_Click(object sender,EventArgs e)
{
spSend.WriteLine(txtSend.Text);
}

public void spReceive_DataReceived(object sender,Ports.SerialDataReceivedEventArgs e)
{
byte[] readBuffer = new byte[spReceive.ReadBufferSize];
spReceive.Read(readBuffer,
0, readBuffer.Length);
this.Invoke(interfaceUpdateHandle, new string[] { Encoding.Unicode.GetString(readBuffer) });
}

private void UpdateTextBox(string text)
{
txtReceive.Text
= text;
}
阅读(6463) | 评论(1) | 转发(0) |
给主人留下些什么吧!~~

chinaunix网友2008-06-25 23:30:41

请问我用你的这种方法读取数据的时候,为什么spReceive_DataReceived 触发两次 ,一次读不完,请帮帮解决liuxiaobing.aptech@163.com 或把你可以运行的代码发一份给我,谢谢