与C#串口通讯有关的文章.docx
《与C#串口通讯有关的文章.docx》由会员分享,可在线阅读,更多相关《与C#串口通讯有关的文章.docx(18页珍藏版)》请在冰豆网上搜索。
与C#串口通讯有关的文章
VB,C#MSComm控件的用法与详细介绍
MSComm是控件
MSComm控件通过串行端口传输和接收数据,为应用程序提供串行通讯功能。
MSComm控件在串口编程时非常方便,程序员不必去花时间去了解较为复杂的API函数,而且在VC、VB、Delphi与C#等语言中均可使用。
MicrosoftCommunicationsControl(以下简称MSComm)是Microsoft公司提供的简化Windows下串行通信编程的ActiveX控件,它为应用程序提供了通过串行接口收发数据的简便方法。
具体的来说,它提供了两种处理通信问题的方法:
一是事件驱动(Event-driven)方法,一是查询法。
1.MSComm控件两种处理通讯的方式
MSComm控件提供下列两种处理通讯的方式:
事件驱动方式和查询方式。
1.1事件驱动方式
事件驱动通讯是处理串行端口交互作用的一种非常有效的方法。
在许多情况下,在事件发生时需要得到通知,例如,在串口接收缓冲区中有字符,或者CarrierDetect(CD)或RequestToSend(RTS)线上一个字符到达或一个变化发生时。
在这些情况下,可以利用MSComm控件的OnComm事件捕获并处理这些通讯事件。
OnComm事件还可以检查和处理通讯错误。
所有通讯事件和通讯错误的列表,参阅CommEvent属性。
在编程过程中,就可以在OnComm事件处理函数中加入自己的处理代码。
这种方法的优点是程序响应及时,可靠性高。
每个MSComm控件对应着一个串行端口。
如果应用程序需要访问多个串行端口,必须使用多个MSComm控件。
1.2查询方式
查询方式实质上还是事件驱动,但在有些情况下,这种方式显得更为便捷。
在程序的每个关键功能之后,可以通过检查CommEvent属性的值来查询事件和错误。
如果应用程序较小,并且是自保持的,这种方法可能是更可取的。
例如,如果写一个简单的电话拨号程序,则没有必要对每接收一个字符都产生事件,因为唯一等待接收的字符是调制解调器的“确定”响应。
2.MSComm控件的常用属性
MSComm控件有很多重要的属性,但首先必须熟悉几个属性。
CommPort设置并返回通讯端口号。
Settings以字符串的形式设置并返回波特率、奇偶校验、数据位、停止位。
PortOpen设置并返回通讯端口的状态。
也可以打开和关闭端口。
Input从接收缓冲区返回和删除字符。
Output向传输缓冲区写一个字符串。
下面分别描述:
CommPort属性设置并返回通讯端口号。
语法object.CommPort[value](value一整型值,说明端口号。
)
说明在设计时,value可以设置成从1到16的任何数(缺省值为1)。
但是如果用PortOpen属性打开一个并不存在的端口时,MSComm控件会产生错误68(设备无效)。
注意:
必须在打开端口之前设置CommPort属性。
RThreshold属性:
在MSComm控件设置CommEvent属性为comEvReceive并产生OnComm之前,设置并返回的要接收的字符数。
语法object.Rthreshold[=value](value整型表达式,说明在产生OnComm事件之前要接收的字符数。
)
说明当接收字符后,若Rthreshold属性设置为0(缺省值)则不产生OnComm事件。
例如,设置Rthreshold为1,接收缓冲区收到每一个字符都会使MSComm控件产生OnComm事件。
CTSHolding属性:
确定是否可通过查询ClearToSend(CTS)线的状态发送数据。
ClearToSend是调制解调器发送到相联计算机的信号,指示传输可以进行。
该属性在设计时无效,在运行时为只读。
语法:
object.CTSHolding(Boolean)
Mscomm控件的CTSHolding属性设置值:
TrueClearToSend线为高电平。
FalseClearToSend线为低电平。
说明:
如果ClearToSend线为低电平(CTSHolding=False)并且超时时,MSComm控件设置CommEvent属性为comEventCTSTO(ClearToSendTimeout)并产生OnComm事件。
ClearToSend线用于RTS/CTS(RequestToSend/ClearToSend)硬件握手。
如果需要确定ClearToSend线的状态,CTSHolding属性给出一种手工查询的方法。
详细信息有关握手协议,请参阅Handshaking属性。
SThreshold属性:
MSComm控件设置CommEvent属性为comEvSend并产生OnComm事件之前,设置并返回传输缓冲区中允许的最小字符数。
语法object.SThreshold[=value]
value整形表达式,代表在OnComm事件产生之前在传输缓冲区中的最小字符数。
说明:
若设置Sthreshold属性为0(缺省值),数据传输事件不会产生OnComm事件。
若设置Sthreshold属性为1,当传输缓冲区完全空时,MSComm控件产生OnComm事件。
如果在传输缓冲区中的字符数小于value,CommEvent属性设置为comEvSend,并产生OnComm事件。
comEvSend事件仅当字符数与Sthreshold交叉时被激活一次。
例如,如果Sthreshold等于5,仅当在输出队列中字符数从5降到4时,comEvSend才发生。
如果在输出队列中从没有比Sthreshold多的字符,comEvSend事件将绝不会发生。
Handshake常数
常数值描述
comNone0无握手。
comXonXoff1XOn/Xoff握手。
comRTS2Request-to-send/clear-to-send握手。
comRTSXOnXOff3Request-to-send和clear-to-send握手皆可。
OnComm常数
常数值描述
comEvSend1发送事件。
comEvReceive2接收事件。
comEvCTS3clear-to-send线变化。
comEvDSR4data-setready线变化。
comEvCD5carrierdetect线变化。
comEvRing6振铃检测。
comEvEOF7文件结束。
Error常数
常数值描述
comEventBreak1001接收到中断信号
comEventCTSTO1002Clear-to-send超时
comEventDSRTO1003Data-setready超时
comEventFrame1004帧错误
comEventOverrun1006端口超速
comEventCDTO1007Carrierdetect超时
comEventRxOver1008接收缓冲区溢出
comEventRxParity1009Parity错误
comEventTxFull1010传输缓冲区满
comEventDCB1011检索端口设备控制块(DCB)时的意外错误
InputMode常数
常数值描述
comInputModeText0(缺省)通过Input属性以文本方式取回数据。
comInputModeBinary1通过Input属性以二进制方式检取回数据。
CDHolding属性:
通过查询CarrierDetect(CD)线的状态确定当前是否有传输。
CarrierDetect是从调制解调器发送到相联计算机的一个信号,指示调制解调器正在联机。
该属性在设计时无效,在运行时为只读。
语法object.CDHolding
设置值:
CDHolding属性的设置值为:
设置描述
TrueCarrierDetect线为高电平
FalseCarrierDetect线为低电平
说明:
注意当CarrierDetect线为高电平(CDHolding=True)且超时时,MSComm控件设置CommEvent属性为comEventCDTO(CarrierDetect超时错误),并产生OnComm事件。
注意在主机应用程序中捕获一个丢失的传输是特别重要的,例如一个公告板,因为呼叫者可以随时挂起(放弃传输)。
CarrierDetect也被称为ReceiveLineSignalDetect(RLSD)。
数据类型Boolean
DSRHolding属性:
确定DataSetReady(DSR)线的状态。
DataSetReady信号由调制解调器发送到相连计算机,指示作好操作准备。
该属性在设计时无效,在运行时为只读。
语法:
object.DSRHolding
object所在处表示对象表达式,其值是“应用于”列表中的对象。
DSRHolding属性返回以下值:
值描述
TrueDataSetReady线高
FalseDataSetReady线低
说明:
当DataSetReady线为高电平(DSRHolding=True)且超时时,MSComm控件设置CommEvent属性为comEventDSRTO(数据准备超时)并产生OnComm事件。
当为DataTerminalEquipment(DTE)机器写DataSetReady/DataTerminalReady握手例程时该属性是十分有用的。
数据类型:
Boolean
Settings属性:
设置并返回波特率、奇偶校验、数据位、停止位参数。
语法:
object.Settings[=value]
说明:
当端口打开时,如果value非法,则MSComm控件产生错误380(非法属性值)。
Value由四个设置值组成,有如下的格式:
"BBBB,P,D,S"
BBBB为波特率,P为奇偶校验,D为数据位数,S为停止位数。
value的缺省值是:
"9600,N,8,1"
InputLen属性:
设置并返回Input属性从接收缓冲区读取的字符数。
语法object.InputLen[=value]
InputLen属性语法包括下列部分:
value整型表达式,说明Input属性从接收缓冲区中读取的字符数。
说明:
InputLen属性的缺省值是0。
设置InputLen为0时,使用Input将使MSComm控件读取接收缓冲区中全部.
对于从事工控和单片机工作的人来说串口编程是很常用的和很重要的。
事实上在VB.net和C#中对串口的操作和VS6里没有大的区别。
你仍然可以直接调用API或者使用MSComm或其他第三方控件。
这里只介绍大家常用的MSComm。
例子使用2、3脚跳过线的串口将COM1和COM2连接。
首先,你必须有MSComm.ocx文件在你的Windows的System32目录下,而且它必须正确的注册。
你可以装VS6来获得,微软也指出这样不会有冲突。
当然我们可以自己注册而不用装庞大的VS6。
先将MSComm.ocx复制到System32目录下,然后使用edit工具编辑一个以.reg扩展名的文件,在文件里输入以下的文字
REGEDIT
HKEY_CLASSES_ROOT\Licenses=Licensing:
Copyingthekeysmaybeaviolationofestablishedcopyrights.
//TheMsComm32ControlLicensefollows:
HKEY_CLASSES_ROOT\Licenses\4250E830-6AC2-11cf-8ADB-00AA00C00905=kjljvjjjoquqmjjjvpqqkqmqykypoqjquoun
然后,存盘。
双击文件就完成了注册。
现在,我们介绍一下MSComm在VB.net和C#中和VS6里的不同和实际的应用。
在VB.net或C#中建立一个窗口Form1。
加入两个MSComm控件,你会发现这里MSComm的默认名字是axMSComm,有点奇怪吧。
同时因为命名空间的问题你不能给axMSComm1.InputMode赋0或1这样的值。
你只能这样来做如axMSComm1.InputMode=MSCommLib.InputModeCInputModeBinary或者axMSComm1.InputMode=MSCommLib.InputModeCInputModeText。
现在我们在窗口中加入textBox和button控件。
在Form1_Load中加入以下的代码(C#版本):
try
{
axMSComm1.PortOpen=true;
axMSComm2.PortOpen=true;
}
catch
{
MessageBox.Show("串口操作失败");
}
(VB.net版本)
Try
axMSComm1.PortOpen=True
axMSComm2.PortOpen=True
Catch
MsgBox("串口操作失败",MsgBoxStyle.Critical)
EndTry
在button的Click事件中加入以下代码:
(C#版本)
byte[]bytOut=newbyte[1];
bytOut[0]=255;
axMSComm2.Output=bytOut;
//这里我们只发一字节0ffh如果发更多可以定义更大的数组
(VB.net版本)
DimbytOutasbyte=255
axMSComm2.Output=bytOut
现在在axMSComm1_OnComm中加入
(C#版本)
stringstrIn=""
byte[]bytIn;
objectobjIn;
inti;
axMSComm1.InputMode=MSCommLib.InputModeCInputModeBinary;
axMSComm1.InputLen=0;
objIn=axMSComm1.Input//这里注意axMSComm1.Input返回的是一个object的
bytIn=(byte[])objIn;//类型,所以必须使用显式的类型转换,这点和VB不同
for(i=0;i<=(bytIn.Length-1);i++)
{
strIn+="\r\n"+""+bytIn[i].ToString("X");//转换为16进制显示
}
textBox1.Text+=strIn;
(VB.net版本)
DimstrInasstring=””
DimbytIn()asbyte
DimIasInteger
axMSComm1.InputMode=MSCommLib.InputModeCInputModeBinary
axMSComm1.InputLen=0
bytIn=axMSComm1.Input
Fori=0ToUBound(bytInput)
strIn+="\r\n"+""+Hex(bytIn[i])
Next
textBox1.Text+=strIn
这里请注意C#在接收的时候与VB的不同。
将axMSComm1的属性RThreshold设置为1,axMSComm1和axMSComm2的SThreshold设置为0。
现在可以编译运行了,请用一条2、3脚跳过线的NullModem线连接计算机的COM1和COM2,运行后,点击button你应该在textBox中看到FF并换行。
这里使用axMSComm1接收axMSComm2发送,只发了一个字节,但更多的字节发送也没什么问题,只要定义更大的数组就可以了,当然如果你感觉MSComm不够强大你可以调用api或者自己定义一个控制串口的类。
MSComm的其他的属性和VS6中没什么太大的不同,你可以自己试试。
接收数据在OnComm事件中写就可以了.不过你首先要注册一下mscomm.ocx
第一步:
将Mscomm.srg,Mscomm32.ocx,Mscomm32.dep三个文件复制到系统文件夹中。
第二步:
用Windows下的注册工具regsvr32注册该OCX控件,点击“开始”->"运行",再在中填入(假设操作安装在C盘,WIN2000):
Regsvr32C:
\winnt\system32\Mscomm32.ocx
第三步:
在注册表中手工新建一个主键项:
先在点击“开始”->"运行",再在中填入regedit命令打开注册表,找到HKEY_CLASSES_ROOT\Licenses,在其中添加主键
4250E830-6AC2-11cf-8ADB-00AA00C00905 并将内容设置为:
kjljvjjjoquqmjjjvpqqkqmqykypoqjquoun
注册后就可以在vs项目中使用了.
MSComm控件使用详解
MSComm控件通过串行端口传输和接收数据,为应用程序提供串行通讯功能。
MSComm控件在串口编程时非常方便,程序员不必去花时间去了解较为复杂的API函数,而且在VC、VB、Delphi等语言中均可使用。
MicrosoftCommunicationsControl(以下简称MSComm)是Microsoft公司提供的简化Windows下串行通信编程的ActiveX控件,它为应用程序提供了通过串行接口收发数据的简便方法。
具体的来说,它提供了两种处理通信问题的方法:
一是事件驱动(Event-driven)方法,一是查询法。
1.MSComm控件两种处理通讯的方式
MSComm控件提供下列两种处理通讯的方式:
事件驱动方式和查询方式。
1.1事件驱动方式
事件驱动通讯是处理串行端口交互作用的一种非常有效的方法。
在许多情况下,在事件发生时需要得到通知,例如,在串口接收缓冲区中有字符,或者CarrierDetect(CD)或RequestToSend(RTS)线上一个字符到达或一个变化发生时。
在这些情况下,可以利用MSComm控件的OnComm事件捕获并处理这些通讯事件。
OnComm事件还可以检查和处理通讯错误。
所有通讯事件和通讯错误的列表,参阅CommEvent属性。
在编程过程中,就可以在OnComm事件处理函数中加入自己的处理代码。
这种方法的优点是程序响应及时,可靠性高。
每个MSComm控件对应着一个串行端口。
如果应用程序需要访问多个串行端口,必须使用多个MSComm控件。
1.2查询方式
查询方式实质上还是事件驱动,但在有些情况下,这种方式显得更为便捷。
在程序的每个关键功能之后,可以通过检查CommEvent属性的值来查询事件和错误。
如果应用程序较小,并且是自保持的,这种方法可能是更可取的。
例如,如果写一个简单的电话拨号程序,则没有必要对每接收一个字符都产生事件,因为唯一等待接收的字符是调制解调器的“确定”响应。
2.MSComm控件的常用属性
MSComm控件有很多重要的属性,但首先必须熟悉几个属性。
CommPort设置并返回通讯端口号。
Settings以字符串的形式设置并返回波特率、奇偶校验、数据位、停止位。
PortOpen设置并返回通讯端口的状态。
也可以打开和关闭端口。
Input从接收缓冲区返回和删除字符。
Output向传输缓冲区写一个字符串。
下面分别描述:
CommPort属性设置并返回通讯端口号。
语法object.CommPort[value](value一整型值,说明端口号。
)
说明在设计时,value可以设置成从1到16的任何数(缺省值为1)。
但是如果用PortOpen属性打开一个并不存在的端口时,MSComm控件会产生错误68(设备无效)。
注意:
必须在打开端口之前设置CommPort属性。
RThreshold属性:
在MSComm控件设置CommEvent属性为comEvReceive并产生OnComm之前,设置并返回的要接收的字符数。
语法object.Rthreshold[=value](value整型表达式,说明在产生OnComm事件之前要接收的字符数。
)
说明当接收字符后,若Rthreshold属性设置为0(缺省值)则不产生OnComm事件。
例如,设置Rthreshold为1,接收缓冲区收到每一个字符都会使MSComm控件产生OnComm事件。
CTSHolding属性:
确定是否可通过查询ClearToSend(CTS)线的状态发送数据。
ClearToSend是调制解调器发送到相联计算机的信号,指示传输可以进行。
该属性在设计时无效,在运行时为只读。
语法:
object.CTSHolding(Boolean)
Mscomm控件的CTSHolding属性设置值:
TrueClearToSend线为高电平。
FalseClearToSend线为低电平。
说明:
如果ClearToSend线为低电平(CTSHolding=False)并且超时时,MSComm控件设置CommEvent属性为comEventCTSTO(ClearToSendTimeout)并产生OnComm事件。
ClearToSend线用于RTS/CTS(RequestToSend/ClearToSend)硬件握手。
如果需要确定ClearToSend线的状态,CTSHolding属性给出一种手工查询的方法。
详细信息有关握手协议,请参阅Handshaking属性。
SThreshold属性:
MSComm控件设置CommEvent属性为comEvSend并产生OnComm事件之前,设置并返回传输缓冲区中允许的最小字符数。
语法object.SThreshold[=value]
value整形表达式,代表在OnComm事件产生之前在传输缓冲区中的最小字符数。
说明:
若设置Sthreshold属性为0(缺省值),数据传输事件不会产生OnComm事件。
若设置Sthreshold属性为1,当传输缓冲区完