MSComm控件实现串口通信的方法
VB6.0下MSComm控件实现串口通信
VB6.0下用MSComm控件实现串口通信MSComm控件通过串行端口传输和接收数据,为应用程序提供串行通讯功能,以下先对其属性进行详细的说明后再举一个例子进行说明:1基本属性CommPortO mPort[=value]Object为MSComm控件,value为整数值,标志端口号。
说明:该属性设置并返回通讯端口号,value的值可以设为1-16间的任意数(默认为1)。
在打开端口之前必须先设置CommPort属性,当端口不存在时,如果用PortOpen属性打开它,MSComm控件会产生错误68(即设备无效的错误)。
SettingsObjiect.Setting[=value]Object为MSComm控件,value为字符串类型,表示通讯端口的设置值。
说明:本属性用来设置并返回端口的波特率、奇偶校验位、数据位和停止位参数。
当端口打开时,如果指定的value参数非法,则MSComm控件产生380号(非法属性值)错误。
有效的value参数值由四个设置值组成,有如下格式:“BBBB,P,D,S”,其中BBBB为波特率,P为奇偶校验,D为数据位数,S为停止位数。
Value的默认值为:“9600,N,8,1”,下面给出合法的波特率、奇偶校验位、数据位和停止位参数:波特率:110,300,600,1200,2400,4800,9600(默认),14400,19200,28800,38400,56000,57600,115200,128000,256000。
奇偶校验值:E(偶校验,Even)、M(标记,Mark)、N(默认,Default,None)、O(奇校验,Odd)、S(空格,Space)。
数据位值:4,5,6,7,8(默认),9。
停止位值:1(默认),1.5,2。
PortOpenO bject.PortOpen[=value]Object为MSComm控件。
Value为布尔类型,表明通讯端口的状态。
vb串口通信控件-mscomm
vb串口通信控件-mscommMSComm控件提供了两种处理通信的方式:一种为事件驱动方式,该方式相当于一般程序设计中的中断方式。
当串口发生事件或错误时,MSComm控件会产生OnComm事件,用户程序可以捕获该事件进行相应处理。
本文的两个例子均采用该方式。
另一种为查询方式,在用户程序中设计定时或不定时查询 MSComm控件的某些属性是否发生变化,从而确定相应处理。
在程序空闲时间较多时可以采用该方式。
常用属性和方法利用MSComm控件实现计算机通信的关键是理解并正确设置MSComm控件众多属性和方法。
以下是MSComm控件的常用属性和方法:●Commport:设置或返回串口号。
●Settings:以字符串的形式设置或返回串口通信参数。
●Portopen:设置或返回串口状态。
●InputMode:设置或返回接收数据的类型。
●Inputlen:设置或返回一次从接收缓冲区中读取字节数。
●InBufferSize:设置或返回接收缓冲区的大小,缺省值为1024字节。
●InBufferCount:设置或返回接收缓冲区中等待计算机接收的字符数。
●Input:从接收缓冲区中读取数据并清空该缓冲区,该属性设计时无效,运行时只读。
●OutBufferSize:设置或返回发送缓冲区的大小,缺省值为512字节。
●OutBufferCount:设置或返回发送缓冲区中等待计算机发送的字符数。
●Output:向发送缓冲区发送数据,该属性设计时无效,运行时只读。
●Rthreshold:该属性为一阀值。
当接收缓冲区中字符数达到该值时,MSComm控件设置Commevent属性为ComEvReceive,并产生OnComm事件。
用户可在OnComm事件处理程序中进行相应处理。
若Rthreshold属性设置为0,则不产生OnComm事件。
例如用户希望接收缓冲区中达到一个字符就接收一个字符,可将Rthreshold设置为1。
这样接收缓冲区中接收到一个字符,就产生一次OnComm事件。
C_builder5中基于MSComm控件串口通信的编程与实现
收稿日期:2001-09-17作者简介:罗日成(1970-),男,湖南隆回人,硕士,长沙电力学院讲师,主要从事遗传算法及控制软件方面的设计开发。
C ++builder5中基于MSC omm 控件串口通信的编程与实现罗日成,李卫国(长沙电力学院电力系,湖南长沙 410077)摘 要:由于串行接口具有连接简单、使用方便、数据传递可靠等优点,在工业实时控制系统中得到了广泛应用。
本文探讨了基于Windows98平台上利用Micros oft C ommunications C ontrol 控件编写串行通信程序的方法,并结合开发实践,阐述了用C ++builder5语言实现了基于ActiveX 技术的串行通信编程的一般步骤。
实践表明,该方法简单、可靠,从而大大缩短实时控制软件的开发周期,减少程序员的工作量。
关 键 词:串行通信;Windows98;C ++builder5;ActiveX 控件;数据采集中图分类号:TP319; 文献标识码:A 文章编号:1001-4551(2002)01-0024-04The Programming and R ealization of Serial Communicationin C ++builder 5B ased MSComm ControlLUO Ri 2cheng ,LI Wei 2guo(Department o f Electr.Power Eng.,Changsha Univer sity o f Electr.Power.,Changsha 410077)Abstract :Serial inter face possesses the g ood qualities of connecting sim ply ,using conveniently and data trans fering credibly ,s o it has gained abroad appliance in real 2time control system.In this paper ,the method of serial communication ’s programming with M icros oft C ommunication C ontrol in the Windows 98platform is discussed ,the approach of serial communication ’s programming which is based on the technique of ActiveX in C ++Builder5.0is expatiated.The method is sim pleness and credibility.I t can shorten programming period greatly and reduce the w ork of the programmer.K ey w ords :serial communication ;Windows98;C ++Builder5;ActiveX control ;data collection1 引 言目前,计算机的串行通信应用十分广泛,串行接口已成为计算机的必需部件和接口之一。
vc 使用mscomm控件实现串口通讯
vc 使用mscomm控件实现串口通讯2009-07-07 08:34mscomm控件是微软发布的串口通讯控件,可以被多种开发工具使用,本章简单介绍vc环境下该控件的使用情况.1、控件的装载。
新建一个mfc工程,选择project-add to project-components and controls打开components and controls gallery对话框,双击 registered actives controls ,做出如下图的选择:点插入按钮后,就可把把该控件安装到controls面板上,同时创建串口类,我们从controls面板上把该控件添加到应用程序对话框就可以使用该控件设计通讯程序了。
2、初始化并打开串口。
m_ctrlComm.SetCommPort(1); //选择串口1if(!m_ctrlComm.GetPortOpen())//如果串口没有打开,则打开串口m_ctrlComm.SetPortOpen(TRUE);m_ctrlComm.SetSettings("38400,n,8,1");//波特率38400,无校验,8个数据位,1个停止位m_ctrlComm.SetInputMode(1);//以二进制方法检取数据m_ctrlComm.SetRThreshold(1);//参数为1表示当串口接收缓冲区有多于或等于1个字符时,将出发一个//接收数据的OnComm事件m_ctrlComm.SetInputLen(0);//设置当前接收缓冲区的数据长度为0m_ctrlComm.GetInput();//先预读缓冲区以清除残留数据3、串口关闭。
m_ctrlComm.SetPortOpen(FALSE);4、数据发送strSendFrame = "10 40 01 41 16 ";CStringToCByteArray(strSendFrame,cbaSendBuf);//转换为字节流cbaLastSendFrameBuf.Copy(cbaSendBuf);ucLastSendCtlCode = cbaSendBuf[1];pView->m_ctrlComm.SetOutput((COleVariant)cbaSendBuf);//串口发送5、数据接收响应mscomm控件的oncomm事件处理接收到的数据。
VB6.0环境下利用Mscomm控件实现串行通信
VB6.0环境下利用Mscomm控件实现串行通信Use Mscomm Control Component to Implement Serial Communication under Visual Basic摘要: 本文简要介绍了VB6.0中Mscomm通信控件的属性和使用方法,并结合具体实例给出了基本的通信程序。
主题词:串行通信Visual Basic Mscomm .vbx控件Abstract: This paper briefly introduces the principle and method of Mscomm object of Visual basic 6.0, and with a real example basic program codes are given.Key Words:Serial Communication; Visual Basic; Mscomm .vbx control component随着计算机技术的飞速发展及其广泛应用,远程控制以及数据采集系统多采用上位机和下位机的主从工作方式,由于串行通信具有高效可靠、价格便宜,遵循统一的标准等特点,因而成为主要的通信手段。
微机的分析处理能力较强,有很好的人机界面和大容量的多种存储方式,所以上位机一般采用微机。
而单片机具有价格低,功能强,抗干扰能力好,温限宽和面向控制等特点,所以下位机采用单片机来构成主从式多机工作模式。
在需要对采集的数据进行分析处理或在远程需要对控制对象的控制过程进行统计或有条件控制时,采用数据库访问技术能有效地解决这类问题。
Visual Basic 6.0以其强大的功能、使用简单、能在短时间内开发出高效的通信程序而成为Windows系统开发的主要编程语言。
首先表现在VB可直接使用户自定义控件VBX或OCX文件;其次表现在VB可通过调用动态链接库(DLL,dynamic link library)来加快应用程序关键部分的执行速度。
C#串口通信:MSComm控件使用详解
C#串口通信:MSComm控件使用详解目次MSComm 控件两种处理通讯的方式CommPort 属性RThreshold 属性CTSHolding 属性SThreshold 属性CDHolding 属性DSRHolding 属性Settings 属性InputLen 属性EOFEnable 属性Handshake 常数OnComm 常数InputMode 常数错误消息MSComm 控件通过串行端口传输和接收数据,为应用程序提供串行通讯功能。
MSComm控件在串口编程时非常方便,程序员不必去花时间去了解较为复杂的API函数,而且在VC、VB、Delphi 等语言中均可使用。
Microsoft Communications Control(以下简称MSComm)是Microsoft公司提供的简化Windows下串行通信编程的ActiveX控件,它为应用程序提供了通过串行接口收发数据的简便方法。
具体的来说,它提供了两种处理通信问题的方法:一是事件驱动(Event-driven)方法,一是查询法。
1.MSComm控件两种处理通讯的方式MSComm控件提供下列两种处理通讯的方式:事件驱动方式和查询方式。
1.1 事件驱动方式事件驱动通讯是处理串行端口交互作用的一种非常有效的方法。
在许多情况下,在事件发生时需要得到通知,例如,在串口接收缓冲区中有字符,或者Carrier Detect (CD) 或Request To Send (RTS) 线上一个字符到达或一个变化发生时。
在这些情况下,可以利用MSComm 控件的OnComm 事件捕获并处理这些通讯事件。
OnComm 事件还可以检查和处理通讯错误。
所有通讯事件和通讯错误的列表,参阅CommEvent 属性。
在编程过程中,就可以在OnComm事件处理函数中加入自己的处理代码。
这种方法的优点是程序响应及时,可靠性高。
每个MSComm 控件对应着一个串行端口。
如果应用程序需要访问多个串行端口,必须使用多个MSComm 控件。
串口通信MSComm控件和SerialPort
一.概述输送带控制模块的核心技术是与PLC的串口通讯,在Visual Studio 6.0中编写串口通讯程序,一般都使用Microsoft Communication Control(简称MSComm)的通讯控件,只要通过对此控件的属性和事件进行相应编程操作,就可以轻松地实现串口通讯。
但在技术广泛应用的今天,Visual S 没有将此控件加入控件库,所以人们采用了许多方法在Visual 来编写串口通讯程序:第一种方法是通过采用Visual Studio 6.0中原来的MSComm控件这是最简单的,最方便的方法,但需要注册;第二种方法是采用微软在.NET推出了一个串口控件,基于.NET的P/Invoke调用方法实现;第三种方法是自己用API写串口通信,虽然难度高,但可以方便实现自己想要的各种功能。
现在微软推出了最新版本的Visual Studio 2005开发工具,可以不再采用第三方控件的方法来设计串口通讯程序。
NET Framework 2.0类库包含了SerialPort类,方便地实现了所需要串口通讯的多种功能,为了使MSComm编程方法快速转换到以SerialPort类为核心的串口通讯的设计方法,这里着重讨论了Visual Studio 6.0的MSComm控件和SerialPort类设计方法的异同点。
二.SerialPort常用属性、方法和事件1.命名空间System.IO.Ports命名空间包含了控制串口重要的SerialPort类,该类提供了同步I/O 和事件驱动的I/ O、对管脚和中断状态的访问以及对串行驱动程序属性的访问,所以在程序代码起始位置需加入Using Sys tem.IO.Ports。
2.串口的通讯参数串口通讯最常用的参数就是通讯端口号及通讯格式(波特率、数据位、停止位和校验位),在MSComm 中相关的属性是CommPort和Settings。
SerialPort类与MSComm有一些区别:✍通讯端口号[PortName]属性获取或设置通信端口,包括但不限于所有可用的COM 端口,请注意该属性返回类型为String,不是mPort的short类型。
VB控件MSComm串口通讯实例教程
现有电子秤一台,使用串口与计算机进行通讯。
编写VB程序来访问串口,达到读取电子秤上显示的数据。
该电子秤为BE01型仪表,输出为RS-232C标准接口,波特率为300-9600、偶校验、7个数据位、2个停止位。
所有字符现有电子秤一台,使用串口与计算机进行通讯。
编写VB程序来访问串口,达到读取电子秤上显示的数据。
该电子秤为BE01型仪表,输出为RS-232C标准接口,波特率为300-9600、偶校验、7个数据位、2个停止位。
所有字符均发送11位ASCII码,一个起始位。
在VB中与串口通讯需要引入控件MSComm串口通讯控件(在Microsoft Comm Control 6.0中)。
具体程序如下:控件简称:MSCDim Out(12) As Byte '接收var中的值Dim var As Variant '接收MSC.input中的数值Dim nRece As Integer '计算MSC.inputbuffer的个数Dim i As Integer, j As Integer '随即变量,计算循环************************************************************************** **Private Sub Form_Load()ClearTextWith MSC.CommPort = 1 '设置Com1为通信端口.Settings = "9600,E,7,2" '设置通信端口参数 9600赫兹、偶校验、7个数据位、2个停止位.(这里需要进一步说明的是:.Setting=”BBBB,P,D,S”。
含义是:B:Baud Rate(波特率);P:Parity(奇偶);D:Data Bit;S:Stop Bit).InBufferSize = 40 '设置缓冲区接收数据为40字节.InputLen = 1 '设置Input一次从接收缓冲读取字节数为1.RThreshold = 1 '设置接收一个字节就产生OnComm事件End WithEnd Sub************************************************************************** **Private Sub ClearText()Text3.Text = ""Text2.Text = "5"Text1.Text = ""End SubPrivate Sub Command1_Click()ClearText' nRece = 0 '计数器清零With MSC.InputMode = comInputModeBinary '设置数据接收模式为二进制形式.InBufferCount = 0 '清除接收缓冲区If Not .PortOpen Then.PortOpen = True '打开通信端口End IfEnd WithEnd SubPrivate Sub MSC_OnComm()DelayTime ‘用来延续时间ClearTextWith MSCSelect Case .CommEvent '判断通信事件Case comEvReceive: '收到Rthreshold个字节产生的接收事件SwichVar 1If Out(1) = 2 Then '判断是否为数据的开始标志.RThreshold = 0 '关闭OnComm事件接收End IfDoDoEventsLoop Until .InBufferCount >= 3 '循环等待接收缓冲区>=3个字节' nRece = nRece + 1For i = 2 To 12SwichVar iText1.Text = Text1.Text & Chr(Out(i))NextText1.Text = LTrim(Text1.Text)Text2.Text = Text2.Text & CStr(nRece).RThreshold = 1 '打开MSComm事件接收Case Else' .PortOpen = FalseEnd SelectEnd WithEnd Sub************************************************************************** **Private Sub DelayTime()Dim bDT As BooleanDim sPrevious As Single, sLast As SinglebDT = TruesPrevious = Timer (Timer可以计算从子夜到现在所经过的秒数,在Microsoft Windows中,Timer函数可以返回一秒的小数部分)Do While bDTIf Timer - sPrevious >= 0.3 Then bDT = FalseLoopbDT = True(通信传输速率为9600bps,则最快速度1.04ms发送一个字节,仪表每秒发送50帧数据,每帧数据有4个字节,即每秒发送200个字节,平均5.0ms 发送一个字节,连续读取串口数据时要在程序中添加循环等待程序)Private Sub SwichVar(ByVal nNum As Integer)DelayTimevar = Nullvar = MSC.InputOut(nNum) = var(0)End Sub(设置接收数据模式采用二进制形式,即 InputMode=comInputModeBinary,但用Input 属性读取数据时,不能直接赋值给 Byte 类型变量,只能通过先赋值给一个 Variant 类型变量,返回一个二进制数据的数组,再转换保存到Byte类型数变量中。
用C#使用MSComm控件进行串口编程
用C#使用MSComm控件进行串口编程对于从事工控和单片机工作的人来说串口编程是很常用的和很重要的。
事实上在和C#中对串口的操作和VS6里没有大的区别。
你仍然可以直接调用API或者使用MSComm或其他第三方控件。
这里只介绍大家常用的MSComm。
例子使用2、3脚跳过线的串口将COM1和COM2连接。
首先,你必须有MSComm.ocx文件在你的Windows的System32目录下,而且它必须正确的注册。
你可以装VS6来获得,微软也指出这样不会有冲突。
当然我们可以自己注册而不用装庞大的VS6。
先将MSComm.ocx复制到System32目录下,然后使用edit 工具编辑一个以.reg扩展名的文件,在文件里输入以下的文字REGEDITHKEY_CLASSES_ROOTLicenses = Licensing: Copying the keys may be a violation of established copyrights.// The MsComm32 Control License follows:HKEY_CLASSES_ROOTLicenses4250E830-6AC2-11cf-8ADB-00AA00C00905 = kjljvjjjoquqmjjjvpqqkqmqykypoqjquoun 然后,存盘。
双击文件就完成了注册。
现在,我们介绍一下MSComm在和C#中和VS6里的不同和实际的应用。
在或C#中建立一个窗口Form1。
加入两个MSComm控件,你会发现这里MSComm的默认名字是axMSComm,有点奇怪吧。
同时因为命名空间的问题你不能给axMSComm1.InputMode赋0或1这样的值。
你只能这样来做如axMSComm1.InputMode=MSCommLib.InputModeConstants.co mInputModeBinary或者axMSComm1.InputMode=MSCommLib.InputModeConstants.co mInputModeText。
MSComm控件的应用(串口编程)
MSComm控件的应用(串口编程)MSComm控件通过串行端口发送和接收数据,为应用程序提供了串行通讯功能。
在基于对话框的应用程序中加入一个MSComm控件非常简单。
只需打开“Project->AddToProject->Components and Controls->Registered Activex Controls”,然后选择控件:Microsoft Communication Control,version 6.0插入到当前的工程中。
CMS m类的相关文件 mscomm.cpp 和 mscomm.h 就加到工程中了。
从工具箱中把MSComm控件拖到对话框上,给控件关联成员变量m_Comm。
1.初始化串口,一般在OnInitDialog()函数中m_Comm.SetCommPort(1); //选择COM1m_Comm.SetInputMode(1); //设置数据通讯格式为二进制数组格式0.为文本格式//1.为二进制数组格式m_Comm.SetSettings("9600,n,8,1");//设置波特率为9600bps,无奇偶校验位,数据位8//位,停止位1位m_Comm.SetRThreshold(1); //设置为每次接到一个字节数据就触发OnComm事件m_Comm.SetInputLen(0);//设置当前接收区数据长度为0,表示全部读取波特率:110、300、600、1200、2400、4800、9600、14400、19200、28800、38400、115200 奇偶校验:E偶校验、M标号校验、N无校验、O奇校验、S空格校验数据位:4、5、6、7、8停止位:1、1.5、22.打开串口if(!m_Comm.GetPortOpen()) //如果串口是关闭的,则行打开串口{m_Comm.SetPortOpen(true);m_Comm.GetInput(); //清除串口输入缓冲区中残留数据}else{AfxMessageBox("串口打开失败!");}3.关闭串口if(m_Comm.GetPortOpen()){m_Comm.SetPortOpen(false);}4.接受数据,OnComm()函数中,数据保存在RcvData中VARIANT m_input;char *str;int len,nEvent;CString RcvData;nEvent = m_Comm.GetCommEvent();switch(nEvent){case 2:len=m_Comm.GetInBufferCount(); //接收缓冲区的字符数目if(len>0){m_input=m_Comm.GetInput();str=(char*)(unsigned char*)m_input.parray->pvData;}*(str+len) = '\0’;RcvData.Format("%s", str);}5.发送数据,把str数据发送出去int i,Count;Count=str.GetLength();CByteArray m_Array;m_Array.RemoveAll();m_Array.SetSize(Count);for(i=0;i<Count;i++){m_Array.SetAt(i,str[i]);}m_Comm.SetOutput(COleVariant(m_Array));。
VC++下用MSComm控件实现串口通讯
VC++下用MSComm控件实现串口通讯首先,在对话框中创建通信控件,若Control工具栏中缺少该控件,可通过菜单Project --> Add to Project --> Components and Control插入即可,再将该控件从工具箱中拉到对话框中。
此时,你只需要关心控件提供的对Windows 通讯驱动程序的API 函数的接口。
换句话说,只需要设置和监视MSComm控件的属性和事件。
打开所需串口后,需要考虑串口通信的时机。
在接收或发送数据过程中,可能需要监视并响应一些事件和错误,所以事件驱动是处理串行端口交互作用的一种非常有效的方法。
使用OnComm 事件和CommEvent 属性捕捉并检查通讯事件和错误的值。
发生通讯事件或错误时,将触发OnComm 事件,CommEvent 属性的值将被改变,应用程序检查CommEvent 属性值并作出相应的反应// 若是在SDI中使用该控件则要调用下两句,在对话框程序中该语句有MFC自己创建// 所以不用人为添加DWORD style=WS_VISIBLE;m_MSComm.Create(NULL,style,CRect(0,0,0,0),this,IDC_MSCOMM1);// 串口控件的初始化DWORD style=WS_VISIBLE;m_MSComm.Create(NULL,style,CRect(0,0,0,0),this,IDC_MSCOMM1);if(m_MSComm.GetPortOpen()) //如果串口是打开的,则行关闭串口{m_MSComm.SetPortOpen(FALSE);}m_MSComm.SetCommPort(1); //选择COM1m_MSComm.SetInBufferSize(1024); //接收缓冲区m_MSComm.SetOutBufferSize(1024);//发送缓冲区m_MSComm.SetInputLen(0);//设置当前接收区数据长度为0,表示全部读取m_MSComm.SetInputMode(1);//以二进制方式读写数据m_MSComm.SetRThreshold(1);//接收缓冲区有1个及1个以上字符时,将引发接收数据的OnComm事件m_MSComm.SetSettings("9600,n,8,1");//波特率9600无检验位,8个数据位,1个停止位if(!m_MSComm.GetPortOpen())//如果串口没有打开则打开m_MSComm.SetPortOpen(TRUE);//打开串口elsem_MSComm.SetOutBufferCount(0);// 控件事件的响应声明// *.h//{{AFX_MSG(CGolfView)afx_msg BOOL OnComm();DECLARE_EVENTSINK_MAP()//}}AFX_MSG// *.cppBEGIN_EVENTSINK_MAP(CGolfView, CView)//{{AFX_EVENTSINK_MAP(CAboutDlg)ON_EVENT(CGolfView, IDC_MSCOMM1, 1 /* OnComm */, OnComm, VTS_NONE) //}}AFX_EVENTSINK_MAPEND_EVENTSINK_MAP()// 控件事件的响应BOOL CGolfView::OnComm(){VARIANT variant_inp;COleSafeArray safearray_inp;LONG len,k;BYTE rxdata[2048]; //设置BYTE数组An 8-bit integerthat is not signed.CString strtemp;switch(m_MSComm.GetCommEvent()){case 1: // comEvSend发送数据break;case 2: // comEvReceive读取数据// MessageBox(_T("读取数据事件"), _T("TRACE"), MB_OK);variant_inp=m_MSComm.GetInput(); //读缓冲区safearray_inp=variant_inp; //VARIANT型变量转换为ColeSafeArray型变量len=safearray_inp.GetOneDimSize(); //得到有效数据长度// 接受数据for(k=0; k<len; k++){safearray_inp.GetElement(&k,rxdata+k); //转换为BYTE型数组BYTE bt=*(char*)(rxdata+k); //字符型strtemp.Format("%c",bt); //将字符送入临时变量strtemp存放recd+=strtemp;}// UpdateData(TRUE);break;default: // 传输事件出错m_MSComm.SetOutBufferCount(0);break;}UpdateData(FALSE); //更新图象内容return TRUE;}核心代码初始化函数BOOL CSCommTestDlg::OnInitDialog(){CDialog::OnInitDialog();// Add "About..." menu item to system menu. made by lzycsd// IDM_ABOUTBOX must be in the system command range.ASSERT((IDM_ABOUTBOX & 0xFFF0) == IDM_ABOUTBOX);ASSERT(IDM_ABOUTBOX < 0xF000);CMenu* pSysMenu = GetSystemMenu(FALSE);if (pSysMenu != NULL){CString strAboutMenu;strAboutMenu.LoadString(IDS_ABOUTBOX);if (!strAboutMenu.IsEmpty()){pSysMenu->AppendMenu(MF_SEPARATOR);pSysMenu->AppendMenu(MF_STRING, IDM_ABOUTB OX, strAboutMenu); }}// Set the icon for this dialog. The framework does this automatically// when the application's main window is not a dialogSetIcon(m_hIcon, TRUE); // Set big iconSetIcon(m_hIcon, FALSE); // Set small icon// TODO: Add extra initialization here////////////////////////////////////////////////////其他初始化m_ctrlComboComPort.SetCurSel(0); //初始选择串口1m_ctrlComboBaudRate.SetCurSel(6); //初始选择波特率9600m_ctrlComboParityBit.SetCurSel(0); //初始选择校验位无m_ctrlComboDataBit.SetCurSel(3); //初始选择数据位8位m_ctrlComboStopBit.SetCurSel(0); //初始选择停止位1位m_strSendPeriod="1000"; //初始自动发送周期为1000毫秒UpdateData(FALSE); //修改编辑框内容//GetDlgItem(IDC_EDIT_SENDPERIOD)->SetWindowText("1000");另一种方法设置////其他初始化//////////////////////////////////////////////////串口初始化m_ctrlComm.SetCommPort(m_ctrlComboComPort.GetCurSel()+1); //选择COM1//波特率9600,无校验,8个数据位,1个停止位m_ctrlComm.SetInputMode(1); //输入方式为二进制方式m_ctrlComm.SetInBufferSize(1024); //设置输入缓冲区大小m_ctrlComm.SetOutBufferSize(512); //设置输出缓冲区大小//波特率9600,无校验,8个数据位,1个停止位m_ctrlComm.SetSettings("9600,N,8,1");if(!m_ctrlComm.GetPortOpen())// {m_ctrlComm.SetPortOpen(TRUE); //打开串口SetPortOpen函数返回值为void// m_ctrlOpenCom.EnableWindow(FALSE); //使按钮变灰//if (!m_ctrlComm.GetPortOpen())// 如果串口已经打开(打开串口失败),会走到这里来,加上你的判断就可以了……// AfxMessageBox("没有发现此串口或被其他程序占用");//m_ctrlCloseCom.EnableWindow(FALSE); //打开串口失败// m_ctrlOpenCom.EnableWindow(TRUE);// }// else// {// m_ctrlOpenCom.EnableWindow(FALSE);// }m_ctrlComm.SetRThreshold(1); //参数1表示每当串口接受缓冲区中有多于或等于1个字符时将引发一个接受数据的OnComm事件m_ctrlComm.SetInputLen(0); //设置当前接受区数据长度为0m_ctrlComm.GetInput(); //先预读缓冲区以清除残留数据m_bSerialPortOpened=TRUE; //串口成功打开m_ctrlOpenCom.EnableWindow(!m_bSerialPortOpened); //打开串口按钮失效m_ctrlCloseCom.EnableWindow(m_bSerialPortOpened); //关闭串口按钮有效return TRUE; // return TRUE unless you set the focus to a control}从串口接受数据并显示在接受编辑框中static long rxdatacount=0; //接受字符计数void CSCommTestDlg::OnComm(){// TODO: Add your control notification handler code hereVARIANT variant_inp;COleSafeArray safearray_inp;LONG len,k;BYTE rxdata[2048]; //设置BYTE数组CString strtemp;if(m_ctrlComm.GetCommEvent()==2) //事件值为2表示接受缓冲区内有字符{variant_inp=m_ctrlComm.GetInput(); //读缓冲区safearray_inp=variant_inp; //VARIANT型变量转换为ColeSafeArray型变量len=safearray_inp.GetOneDimSize(); //得到有效数据长度for(k=0;k<len;k++)safearray_inp.GetElement(&k,rxdata+k); //转换为BYTE型数组for(k=0;k<len;k++) //将数组转换为Cstring型变量{BYTE bt=*(char*)(rxdata+k); //字符型strtemp.Format("%c",bt); //将字符送入临时变量strtemp存放m_strEditRXData+=strtemp; //加入接受编辑框对应字符串//////////////////////////////////////////////////////放在这里计数会卡//rxdatacount++; //接受的字节计数//CString temp;//temp.Format("%ld",rxdatacount);//temp="接受:"+temp;//m_ctrlRXCount.SetWindowText(temp); //显示接受计数////////////////////////////////////////////////////}rxdatacount+=len;//m_ctrlRXCount.SetWindowText("接受:"+rxdatacount);CString temp;temp.Format("%ld",rxdatacount);temp="接受:"+temp;m_ctrlRXCount.SetWindowText(temp); //显示接受计数}UpdateData(FALSE); //更新编辑框内容}点击发送按钮处理函数//手工发送数据long TX_count=0;void CSCommTestDlg::OnButtonManualsend(){// TODO: Add your control notification handler code hereUpdateData(TRUE); //读取编辑框内容m_ctrlComm.SetOutput(COleVariant(m_strEditTXData)); //发送数据X_count+=m_strEditTXData.GetLength(); //发送计数CString strTemp;strTemp.Format("发送:%d",TX_count);m_ctrlTXCount.SetWindowText(strTemp); //显示计数GetDlgItem(IDC_BUTTON_MANUALSEND)->EnableWindow(TRUE);}void CSCommTestDlg::OnEditchangeComboComport(){// TODO: Add your control notification handler code here}改变串口时的处理函数void CSCommTestDlg::OnSelchangeComboComport(){// TODO: Add your control notification handler code here//int Cpos=m_ctrlComboComPort.GetCurSel()+1; //获取当前选择的串口号//测试用//CString myString ;//myString.Format("%d",Cpos);//CWnd* pWnd = GetDlgItem(IDC_STATIC1);//pWnd->SetWindowText(_T(myString));//测试用//if(m_ctrlComm)if(m_ctrlComm.GetPortOpen()){m_ctrlComm.SetPortOpen(FALSE); //关闭串口m_bSerialPortOpened=FALSE; //串口成功关闭m_ctrlOpenCom.EnableWindow(!m_bSerialPortOpened); //打开串口按钮有效m_ctrlCloseCom.EnableWindow(m_bSerialPortOpened); //关闭串口按钮失效}//打开串口//选择相应的波特率,校验位,数据位,停止位m_ctrlComm.SetCommPort(m_ctrlComboComPort.GetCurSel()+1);//选择相应的COMm_ctrlComm.SetInputMode(1); //输入方式为二进制方式m_ctrlComm.SetInBufferSize(1024);//设置输入缓冲区大小m_ctrlComm.SetOutBufferSize(512); //设置输出缓冲区大小//选择相应的波特率,校验位,数据位,停止位CString setstr;CString tempstr;m_ctrlComboBaudRate.GetWindowText(tempstr); //获取波特率setstr=tempstr;setstr+=",";m_ctrlComboParityBit.GetWindowText(tempstr); //获取校验位tempstr=tempstr.Left(1); //取第一个单词setstr=setstr+tempstr+",";m_ctrlComboDataBit.GetWindowText(tempstr); //获取数据位setstr=setstr+tempstr+",";m_ctrlComboStopBit.GetWindowText(tempstr); //获取停止位setstr+=tempstr;/*int BaudRate = 9600;char ParityBit = n;int DataBit = 8;int StopBit = 1;setstr.Format( "%d,%c,%d,%d ",BaudRate,ParityBit,DataBite,StopBit);SetSettings(setstr);*///m_ctrlComm.SetSettings("9600,N,8,1");m_ctrlComm.SetSettings(setstr);if(!m_ctrlComm.GetPortOpen())m_ctrlComm.SetPortOpen(TRUE); //打开串口m_ctrlComm.SetRThreshold(1); //参数1表示每当串口接受缓冲区中有多于或等于1个字符时将引发一个接受数据的OnComm事件m_ctrlComm.SetInputLen(0); //设置当前接受区数据长度为0m_ctrlComm.GetInput(); //先预读缓冲区以清除残留数据m_bSerialPortOpened=TRUE; //串口成功打开m_ctrlOpenCom.EnableWindow(!m_bSerialPortOpened); //打开串口按钮失效m_ctrlCloseCom.EnableWindow(m_bSerialPortOpened); //关闭串口按钮有效}打开串口void CSCommTestDlg::OnButtonOpen(){// TODO: Add your control notification handler code hereif(!m_ctrlComm.GetPortOpen()){m_ctrlComm.SetPortOpen(TRUE);m_bSerialPortOpened=TRUE; //串口成功打开m_ctrlOpenCom.EnableWindow(!m_bSerialPortOpened); //打开串口按钮失效m_ctrlCloseCom.EnableWindow(m_bSerialPortOpened); //关闭串口按钮有效}}关闭串口void CSCommTestDlg::OnButtonClose(){// TODO: Add your control notification handler code hereif(m_ctrlComm.GetPortOpen()){m_ctrlComm.SetPortOpen(FALSE);m_bSerialPortOpened=FALSE; //串口成功关闭m_ctrlOpenCom.EnableWindow(!m_bSerialPortOpened); //打开串口按钮有效m_ctrlCloseCom.EnableWindow(m_bSerialPortOpened); //关闭串口按钮失效}}定时器触发后运行的函数void CSCommTestDlg::OnTimer(UINT nIDEvent){// TODO: Add your message handler code here and/or call default//添加你要处理的函数,当定时时间到时自动调用//通过调用SetTimer(1,1000,NULL)启动定时器,通过调用KillTimer(int nIDEvent)关闭定时器OnButtonManualsend();CDialog::OnTimer(nIDEvent);}选择自动发送触发的函数void CSCommTestDlg::OnCheckAutosend(){// TODO: Add your control notification handler code hereif(m_ctrlAutoSend.GetCheck()){ //自动发送int i=atoi(m_strSendPeriod);SetTimer(1,i,NULL);//函数反回值就是第一个参数值1,表示此定时器的ID号。
MSComm控件进行串口编程的基本步骤
MSComm控件进⾏串⼝编程的基本步骤Visual C++为我们提供了⼀种好⽤的ActiveX控件Microsoft Communications Control(即MSComm)来⽀持应⽤程序对串⼝的访问,在应⽤程序中插⼊MSComm控件后就可以较为⽅便地实现对通过计算机串⼝收发数据。
要使⽤ActiveX控件MSComm,程序员必须将其添加⼊⼯程,其⽅法是: (1)单击主菜单project的⼦菜单Add To project的Components and Controls选项; (2)在弹出的"Components and Controls Gallery"对话框中选择Registered ActiveX Controls⽂件夹中的"Microsoft Communications Control,version 6.0"选项 单击其中的"Insert"按钮,MSComm控件就被增加到⼯程中了。
与此同时,类CMSComm的相关⽂件mscomm.h和mscomm.cpp也⼀并被加⼊Project的Header Files和Source Files中。
当然,程序员可以⾃⼰修改⽂件名1在建⽴的⼯程中插⼊MSComm控件2添加MSComm控件ID的控制变量或对象3对串⼝进⾏初始化,设置MSComm控件的属性4添加串⼝事件的消息处理函数OnComm()函数,在函数中根据应⽤需要,编写数据处理代码5编写串⼝发送等其他代码6关闭串⼝⼀个MSComm控件只能对应⼀个串⼝,如果应⽤程序需要访问多个串⼝,必须使⽤多个MSComm控件。
处理通信问题的⽅式:事件驱动⽅式(与中断原理类似,触发⼀个事件处理函数),查询⽅式。
MSComm控件的重要属性中的⼀部分CommPort设置并返回通信端⼝号Settings以字符串的形式设置并返回波特率、奇偶校验、数据位、停⽌位。
在VS(VC)2010中使用MSComm控件实现串口通信的详细步骤
// TODO: 在¨²此ä?添¬¨ª加¨®控?件t通ª¡§知a处ä|理¤¨ª程¨¬序¨°代䨲码? }
void CCommTestDlg::OnBnClickedButtonOpen() { // TODO: 在¨²此ä?添¬¨ª加¨®控?件t通ª¡§知a处ä|理¤¨ª程¨¬序¨°代䨲码? }
10. 添加关闭串口按钮的消息响应函数 void CCommTestDlg::OnBnClickedButtonClose() { // TODO: 在此添加控件通知处理程序代码 m_mscomm.put_PortOpen(FALSE);//关闭串口 AfxMessageBox(_T("串口 1 已关闭")); } 11. 添加发送按钮消息响应函数 void CCommTestDlg::OnBnClickedButtonSend() { // TODO: 在此添加控件通知处理程序代码 UpdateData(true); //读取编辑框内容 m_mscomm.put_Output(COleVariant(m_EditSend));//发送数据 m_EditSend.Empty(); //发送后清空输入框 UpdateData(false); //更新编辑框内容 } 12. 接收数据 void CCommTestDlg::OnCommMscomm1() { // TODO: 在此处添加消息处理程序代码 static unsigned int cnt=0; VARIANT variant_inp; COleSafeArray safearray_inp; long len,k; unsigned int data[1024]={0}; byte rxdata[1024]; //设置 BYTE 数组 CString strtemp; if(m_mscomm.get_CommEvent()==2) //值为 2 表示接收缓冲区内有字符 {
VC基于MSCOMM控件串口通讯
VC基于MSCOMM控件串口通讯在mfc中进行串口通讯最简单的方法莫过于在对话框中使用MSCOMM控件了,MSComm通信控件提供了一系列标准通信命令的接口,它允许建立串口连接,可以连接到其他通信设备(如Modem).还可以发送命令、进行数据交换以及监视和响应在通信过程中可能发生的各种错误和事件,从而可以用它创建全双工、事件驱动的、高效实用的通信程序。
一、用MSComm控件通信1.串口通信基础知识一般悦来,计算机都有一个或多个串行端口,它们依次为com1、Com2、…,这些串口还提供了外部设备与pC进行数据传输和皿信的通道。
这些串口在CPU和外设之间充当解释器的角色。
当字符数据从CPU 发送给外设时,这些字符数据将被转换成串行比特流数据;当接收数据时,比特流数据被转换为字符数据传递给CPU,再进一步说,在操作系统方面,Windows用通信驱动程序(COMM.DRV)调用API函数发送和接收数据,当用通信控件或声明调用API函数时,它门由COMM. DRV解释并传递给设备驱动程序,作为一个vB程序员,要编写通信程序.只需知道通信控件提供给Windows通信AP1函数的接口即可.换句话说,只需设定和监视通信控件的属性和事件即可。
2.使用Mscomm控件在开始使用MSComm控件之前。
需要先了解其属性、事件或错误属性描述CommPort 设置或返回通信端口号Settings 以字符串的形式设置或返回波特率、奇偶校验、数据位和停止位PortOpen 设置或返回通信端口的状态。
也可以打开和关闭端口Input 返回和删除接收缓冲区中的字符Output 将字符串写入发送缓冲区CommEvent属性为通信事件或错误返回下列值之一。
在该控件的对象库中也可以找到这些常量。
常量值描述ComEventBreak 1001 收到了断开信号ComEventCTSTO 1002 Clear To Send Timeout。
在发送字符时,在系统指定的事1件内,CTS(Clear To Send)线是低电平ComEventDSRTO 1003 Data Set Ready Timeout。
串口通信-MSComm控件使用详解
串口通信-MSComm控件使用详解2012-11-13 09:35 6988人阅读评论(0) 收藏举报控件编程 Delphi编程(13)MSComm 控件通过串行端口传输和接收数据,为应用程序提供串行通讯功能。
MSComm控件在串口编程时非常方便,程序员不必去花时间去了解较为复杂的API函数,而且在VC、VB、Delphi等语言中均可使用。
Microsoft Communications Control(以下简称MSComm)是Microsoft公司提供的简化Windows下串行通信编程的ActiveX控件,它为应用程序提供了通过串行接口收发数据的简便方法。
具体的来说,它提供了两种处理通信问题的方法:一是事件驱动(Event-driven)方法,一是查询法。
1.MSComm控件两种处理通讯的方式1.1 事件驱动方式事件驱动通讯是处理串行端口交互作用的一种非常有效的方法。
在许多情况下,在事件发生时需要得到通知,例如,在串口接收缓冲区中有字符,或者 Carrier Detect (CD) 或 Request To Send (RTS) 线上一个字符到达或一个变化发生时。
在这些情况下,可以利用 MSComm 控件的 OnComm 事件捕获并处理这些通讯事件。
OnComm 事件还可以检查和处理通讯错误。
所有通讯事件和通讯错误的列表,参阅 CommEvent 属性。
在编程过程中,就可以在OnComm事件处理函数中加入自己的处理代码。
这种方法的优点是程序响应及时,可靠性高。
每个MSComm 控件对应着一个串行端口。
如果应用程序需要访问多个串行端口,必须使用多个 MSComm 控件。
1.2 查询方式查询方式实质上还是事件驱动,但在有些情况下,这种方式显得更为便捷。
在程序的每个关键功能之后,可以通过检查 CommEvent 属性的值来查询事件和错误。
如果应用程序较小,并且是自保持的,这种方法可能是更可取的。
例如,如果写一个简单的电话拨号程序,则没有必要对每接收一个字符都产生事件,因为唯一等待接收的字符是调制解调器的“确定”响应。
利用控件MSComm实现计算机的串口通信
机串并 口编程在传真 、 视频 和控 制等 。在 Widw 应用 程序 no s 的开发 中 , 常常需 要 面 临 与外 围数 据 源 设 备 通 信 的 问题 。一 般 多 是 利 用 控 件 MS o C mm设 计 相 应 的 串
∥} A X I C U E } F —N L D S
i df e A X— C MM E T L —H一 2 F B 4 — f! e nd( F S O T S D G i 一 2 2 16
6 C _ D5 8 0 _ 0 0 C F 8 A I L 9 2 l _ 7 E 0 E 4 3 7 C 1 NC UDE ) D
置并返 回波特率 、 奇偶校 验 、 据位 、 止位 ; o — 数 停 Pr t
Oe pn属性 , 能 : 置并 返 回通 讯 端 口的状 态 , 可 功 设 也
一
9 — 5
以打开 和关 闭端 口 ; pt I u 属性 , 能 : 接 收 缓 冲 区 n 功 从 内读 出数据 ; upt 性 , 能 : O tu 属 功 向传 输 缓 冲 区写 一 个字符 串 ] 。
cr e d t t C ar r ee ( D)或 rq etosn R S i c eu s t ed( T )线 上一
串行 通信 是 指 一 条 信 息 的 各 位 数 据 被 逐 位 按 顺序 传送 的通 信方 式 。 串行 通 信 的特 点 是 : 据 位 数 传送 按位 顺序 进行 , 最少 只需 要 一 根 传 输线 即 可完 成, 成本 低 、 送 速 度 慢 。 串行 通 信 的距 离 可 以从 传
目前 , 算 机 的 串 行 通 信 应 用 十 分 广 泛 , 计 串行 接 口已成 为 计 算 机 的必 须 部 件 和 接 口之 一 。计 算
用VisualBasic实现串口通信的三种方法
2. 利用通信控件的实例
Sub Form1 —load ()
form1. show ′设置 COM1
comm1. commport = 1
comm1. Setting = " 9600 ,o ,8 ,1" ′波特率 : 9600 奇校验 ,8
位数据 ,1 位停止位
comm1. Inputlen = 0
一 、利用通信控件( MSCOMM) 完成串口通信
VB 提供了通信控件 MSCOMM,文件名为 MSCOMM. VBX。 该控件可设置串行通信的数据发送和接收 ,对串口状态及串 行通信的信息格式和协议进行设置 。在通信过程中可以触发 OnComm 事件 ,在该事件过程进行数据检验处理及检错 ,还可 以通过编程访问 CommEvent 属性来了解通信的情况 ,进行收 发数据的处理 。每个通信控件对应一个串口 ,如果要访问多 个通信口 ,则要设计多个通信控件 。
利用 VB 提供的这些功能 ,我们可以有三种方法完成串 口通信 。一种是用 VB 提供的具有强大功能的通信控件 ;另一 种方法是调用 WINDOWS API 函数 ,使用 WINDOWS 提供的 通信函数编写移植性强的应用程序 ;第三是利用文件的输 入/ 输出完成 ,该方法简便易行 ,但有一定的局限性 。
EofChar As String 3 1
·6 ·
参数 As 类型 ]) As 类型 在声明中 :DECLARE 表示声明 DLL 中的函数 ,当声明是
不具有返回值的过程时用 SUB 关键字 ,而如果调用的函数具 有返回值 ,则必须用 FUNCTION 关键字将其声明为函数并在 声明语句的最后用 AS 指明函数返回值的类型 。LIB 关键字表 示当前声明的过程或函数是库名所指定的库中函数而非 VB 本身的函数 。库名 ,就是对应动态链接库的名称 ,其中通信函 数在 USER 库中 。ByVal 关键字将原参数数据类型一一对应到 VB 类型中 。
MSComm控件实现串口通信的方法
MSComm控件实现串口通信的方法碧峰晨曦摘要:详细介绍了MSComm控件,并在VC++6.0中利用MSComm控件开发了基于对话框的串口通信实例。
关键词:串口通信,MSComm,VC++图书编号:TP3110.引言串口通信具有实现简单、价格低廉、通信稳定、数据传输可靠等优点,因而广泛应用于各种工业控制系统中。
MSComm控件是微软公司开发的专门用于串口通信的控件。
该控件为开发串口通信程序提供了更加快捷、容易的方法。
在VC++中,对控件属性的操作都是通过特定的函数来实现的,这些函数都是CMSComm类的成员函数。
当声明了一个CMSComm类对象后,就可以通过如下格式调用成员函数来访问控件属性了:<对象名>.<成员函数名>(<参数表>)或<对象名>-><成员函数名>(<参数表>)1.MSComm控件属性及事件1.1 MSComm控件属性MSComm控件有许多属性,最主要的几个属性如下:1)CommPort:设置该属性值可以获取当前程序使用的串口编号。
2)Setting:设置或者获取串行通信的通信参数(包括波特率、奇偶校验类型、数据位数及停止位数等)。
3)PortOpen:设置该属性可以打开或关闭串口。
4)Input:从接收缓冲区中返回并删除数据。
5)Output:向串口通信输出缓冲区写入数据。
6)CommEvent:当MSComm控件在运行时发生错误或产生各种事件时,向程序返回错误或事件类型。
1.2 MSComm控件的事件该控件只有一个事件,即OnComm事件。
当CommEvent属性值发生变化时就会触发OnComm事件。
根据CommEvent属性值来分别执行各种情况下的处理程序。
2 MSComm控件实例应用2.1插入MSComm控件在VC++6.0中新建一个基于对话框的工程,命名为Test。
默认情况下,VC++6.0中不会包含MSComm控件,所以需要我们手动将MSComm控件加载到VC++6.0中。
- 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
- 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
- 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。
MSComm控件实现串口通信的方法碧峰晨曦摘要:详细介绍了MSComm控件,并在VC++6.0中利用MSComm控件开发了基于对话框的串口通信实例。
关键词:串口通信,MSComm,VC++图书编号:TP3110.引言串口通信具有实现简单、价格低廉、通信稳定、数据传输可靠等优点,因而广泛应用于各种工业控制系统中。
MSComm控件是微软公司开发的专门用于串口通信的控件。
该控件为开发串口通信程序提供了更加快捷、容易的方法。
在VC++中,对控件属性的操作都是通过特定的函数来实现的,这些函数都是CMSComm类的成员函数。
当声明了一个CMSComm类对象后,就可以通过如下格式调用成员函数来访问控件属性了:<对象名>.<成员函数名>(<参数表>)或<对象名>-><成员函数名>(<参数表>)1.MSComm控件属性及事件1.1 MSComm控件属性MSComm控件有许多属性,最主要的几个属性如下:1)CommPort:设置该属性值可以获取当前程序使用的串口编号。
2)Setting:设置或者获取串行通信的通信参数(包括波特率、奇偶校验类型、数据位数及停止位数等)。
3)PortOpen:设置该属性可以打开或关闭串口。
4)Input:从接收缓冲区中返回并删除数据。
5)Output:向串口通信输出缓冲区写入数据。
6)CommEvent:当MSComm控件在运行时发生错误或产生各种事件时,向程序返回错误或事件类型。
1.2 MSComm控件的事件该控件只有一个事件,即OnComm事件。
当CommEvent属性值发生变化时就会触发OnComm事件。
根据CommEvent属性值来分别执行各种情况下的处理程序。
2 MSComm控件实例应用2.1插入MSComm控件在VC++6.0中新建一个基于对话框的工程,命名为Test。
默认情况下,VC++6.0中不会包含MSComm控件,所以需要我们手动将MSComm控件加载到VC++6.0中。
(1)单击主菜单project的子菜单Add To project的Components and Controls选项;(2)在弹出的“Components and Controls Gallery”对话框中选择Registered ActiveX Controls文件夹中的“Microsoft Communications Control,version6.0”选项,如图l:图1.插入MSComm控件单击其中的“Insert’’按钮,MSComm控件就被增加到工程中了。
与此同时,类CMSComm的相关文件mscomm.h和mscomm.cpp也一并被加人Project的Header Files和Source Files中。
为了使用MSComm控件,将MSComm控件拖入对话框。
在使用控件编程前还需创建该控件的实例,使用使用ClassWizard添加对话框类CTestDlg的WM_CREATE消息响应函数OnCreate(LPCREATESTRUCT lpCreateStruct) ,在该函数内创建控件实例:int CTestDlg::OnCreate(LPCREATESTRUCT lpCreateStruct){……// TODO: Add your specialized creation code hereDWORD style=WS_VISIBLE|WS_CHILD;if (!myComm.Create(NULL,style,CRect(0,0,0,0),this,IDC_MSCOMM1)){AfxMessageBox("创建MSComm控件失败!");return -1;}return 0;}2.2串口初始化及打开初始化主要完成串口的通信参数设置,设置好参数后就可以打开串口了。
在对话框的头文件Test.h中最顶行,加入引用控件类的代码:#include "mscomm.h"然后,在对话框类的定义代码中加入CMSComm类变量的声明:CMSComm mycomm;在CTestDlg::OnInitDialog()函数中添加串口初始化代码:BOOL CTestDlg::OnInitDialog(){……myComm.SetCommPort(2); //选择COM2myComm.SetSettings("9600,n,8,1"); //波特率9600,无校验,8个数据位,1个停止位myComm.SetInBufferSize(2048); //指定接收缓冲区大小myComm.SetInBufferCount(0); //清空接收缓冲区myComm.SetInputMode(1); //设置数据获取方式myComm.SetInputLen(0); //设置每次读取长度myComm.SetRThreshold(1); //设置接收OnComm事件门限值myComm.SetOutBufferSize(1024); //设置发送缓冲区大小myComm.SetOutBufferCount(0); //清空发送缓冲区myComm.SetSThreshold(1); //设置发送OnComm事件门限myComm.SetPortOpen(1); //打开串口return TRUE; // return TRUE unless you set the focus to a control}2.3 OnComm事件处理MSComm控件一般用OnComm事件来接收数据。
使用ClassWizard加MSComm控件的OnComm消息响应函数OnOnCommMscomm(),该函数的作用为接收数据,其代码如下:void CTestDlg::OnOnCommMscomm(){// TODO: Add your control notification handler code hereV ARIANT input1; //定义V ARIANT类型变量BYTE rxdata[2048]; //定义存放二进制数据的数组long len1,k;COleSafeArray safearray1; //定义COleSafeArray类的实例CString strDis;switch(myComm.GetCommEvent()){case 2://收到RThreshold 个字符//添加接收处理代码input1=myComm.GetInput();//将V ARAIANT变量赋值给COleSafeArray类的实例safearray1=input1;//使用COleSafeArray类的成员函数获取数据长度len1=safearray1.GetOneDimSize();for(k=0;k<len1;k++)//使用COleSafeArray类的成员函数将数据写入数组safearray1.GetElement(&k,rxdata+k);for(k=0;k<1;k++){strDis+=rxdata[k];m_Edit1.SetSel(1000000,1000000);m_Edit1.ReplaceSel(strDis);strDis="|";UpdateData(false);}}}2.4 串口发送数据在对话框上添加一个“发送”按钮,利用ClassWizard为该按钮添加“BN_ CLICKED”消息处理函数onsend(),实现的功能为通过串口发送数据,该函数的代码为:void CTestDlg::OnSend(){// TODO: Add your control notification handler code hereUpdateData(true);CByteArray sendArr;WORD wLength;wLength=m_Edit2.GetLength();//m_Edit2为与文本框联系在一起的CString型成员变量sendArr.SetSize(wLength);for(int i=0;i<wLength;i++){sendArr.SetAt(i,m_Edit2.GetAt(i));}myComm.SetOutput(COleVariant(sendArr));}2.5 程序测试运行程序,在发送编辑框中随意输入点什么,单击发送按钮,在另一端利用串口调试助手实现通信数据的接收和发送。
程序运行情况如图2。
图2.程序测试3.结束语本文介绍了详细介绍了在VC++6.0中利用MSComm控件实现串口通信的过程,并给出了详细的编程代码。
该方法快速、简单,免去了以往利用WindowsAPI 实现串口通信的复杂编程,具有很强的使用性。
[参考文献] (References)[1] 王坤,高贇.基于VC++实现串口通信的方法[J].信息化研究,2010,36(10):52-54[2] 刘书智,李琳娜.Visual C++实践与提高--串口通信与工程应用篇[M].北京:中国铁道出版社,2009[3] 吉翔,李永全.VC++下MSComm控件的串口通信方法[J].电脑开发与应用,2009,22(12):34-36[4] 张瑞卿,胡爱军,张超.基于VC++的PC机与PLC串口通讯的实现[J].设计与研究,2010年第9期:58-61。