vc串口通讯控件MSComm编程—No.1

6 篇文章 0 订阅
3 篇文章 0 订阅

该博客旨在分享IT技术心得,以下是新浪博客地址http://blog.sina.com.cn/qianyumolu,则为分享经济、行业趋势、心灵文章等,有兴趣的朋友可以踩踩,讨论分享

-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------


mfc中进行串口通讯简单的方法莫过于在对话框中使用MSCOMM控件了,MSComm通信控件提供了一系列标准通信命令的接口,它允许建立串口连接,可以连接到其他通信设备(如Modem).
还可以发送命令、进行数据交换以及监视和响应在通信过程中可能发生的各种错误和事件,从而可以用它创建全双工 、事件驱动的、高效实用的通信程序。

一、用MSComm控件通信
1
.串口通信基础知识
    
一般悦来,计算机都有一个或多个串行端口,它们依次为com1Com2,这些串口还提供了外部设备与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件内,CTSClear To Send)线是低电平
ComEventDSRTO   1003    Data Set Ready Timeout
。在发送字符时,在系统指定的事件内,DSRData Set Ready)线是低电平
ComEventFrame   1004    
数据帧错误。硬件检测到一个数据帧错误
ComEventOverrun 1006    
端口溢出。硬件中的字符尚未读,下一个字符又到达,并且丢失
ComEventCDTO    1007    Carrier Detect Time
。在发送字符时,在系统指定的事件内,CDCarrier Detect)线是低电平。CD
                        
也称为RLSDReceive Line Singal Detect,接收线信号检测)
ComEventRxOver  1008    
接收缓冲区溢出。在接收缓冲区中没有空间
ComEventRxParity 1009   
奇偶校验错。硬件检测到奇偶校验错误7
ComEventTxFull  1010    
发送缓冲区满。在对发送字符排队时,发送缓冲区满
ComEventDCB     1011    
检取端口DCBDevice Control Blick)时发生了没有预料到的错误

通信事件包含了下面的设置:
常量                 描述
ComEvSend      1    
发送缓冲区中的字符数比Sthreshold值低
ComEvReceive   2    
接收到了Rthreshold个字符。持续产生该事件,直到使用了Input属性删除了接收缓冲区中的数据
ComEvCTS       3    CTS
Clear To Send)线改变
ComEvDSR       4    DSR
Data Set Ready)线改变。当DSR10改变时,该事件发生
ComEvCD        5    CD
Carrier Detect)线改变ComEvRing6检测到响铃信号。一些URATUniversal AsynchronousReciver-
                    -Transmitters,
通用异步收发器)不支持该事件
ComEvEOF       7    
收到了EOF字符(ASCII字符26

Error
消息(MSComm控件)下表列出了MSComm控件可捕获的错误消息:
常量                             描述
ComInvalidPropertyValue    380   
无效的属性值
ComSetNotSupported         383   
属性只读
ComGetNotSupported         394   
属性只读
ComPortOpen               8000   
端口打开时该存在无效
                          8001   
超时设置必须比0值大
ComPortInvalid            8002   
无效的端口号
                          8003   
属性只在运行时有效
                          8004   
属性在运行时是只读的
ComPortAleadyOpen         8005   
端口已经打开
                          8006   
设备标识符无效或不支持
                          8007   
不支持设备的波特率
                          8008   
指定的字节大小无效
                          8009   
缺省参数错误
                          8010   
硬件不可用(被其他设备锁住)
                          8011   
函数不能分配队列
ComNoOpen                 8012   
设备没有打开
                          8013   
设备已经打开
                          8014   
不能使用通信通知
ComSetCommStateFailed     8015   
不能设置通信状态
                          8016   
不能设置通信事件屏蔽
ComPortNotOpen            8018   
该存在只在端口打开是有效
                          8019   
设备忙
ComReadError              8020   
通信设备读错误
ComDCBError               8021   
检取端口设备控制块时出现内部错误
注意在使用的时候一定要保证两个通讯串口的设置是相同的,否则受到的信息将会产生错误!

由于取值位数的不同,有可能发送的信息要读很多次才能组合成需要的信息!


1
。建立mfc工程,都会撒。  
   
将控件加进来:打开“Project->Add To Project->Components and Controls->Registered Activex Controls”,(中文版本为项目-)添加类->MFC->ActiveX控件MFC类)然后选择控件:Microsoft Communication Control,version 6.0插入到当前的工程中。这样就将类 CMSComm 的相关文件 mscomm.cpp  mscomm.h 一并加入到了工程中。编程时只需将控件对话中的 MSComm 控件拖至你的应用对话框中就OK
2
。定义串口对象:
    CMSComm      m_MSComm;
3
。串口初始化:
   
DWORD style=WS_VISIBLE;
m_MSComm.Create(NULL,style,CRect(0,0,0,0),this,IDC_MSCOMM);
if(m_MSComm.GetPortOpen()) //
如果串口是打开的,则行关闭串口
{
 m_MSComm.SetPortOpen(FALSE);
}
m_MSComm.SetCommPort(1); //
选择COM1
m_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);//
打开串口
else
{
 m_MSComm.SetOutBufferCount(0);
 AfxMessageBox("Open The Serial Port 1 Failurre!");
}

4
。串口数据读写:
MSComm 类的读写函数比较简单:GetInput()SetOutput()。函数原形分别为VARIANT GetInput()void SetOutputconst VARIANT newValue,均使用VARIANT类型。但PC机发送和接收数据时习惯用字符串形式。MSDN中查阅VARIANT类型,可以用BSTR表示字符串,但所有的BSTR都包含宽字符,而只有Windows NT支持宽字符,Windows 9X并不支持。所以要完成一个适应各平台的串口应用程序必须解决这个问题。这里使用CbyteArray即可解决之。
 
发数据:在对话框对加入 按钮 控件并给你添加消息
   void CTest_mscommDlg::OnSend() 
{
 // TODO: Add your control notification handler code here
 int i,Count;
 CString m_SendData;
 m_SendData="Hello!"; 
 Count=m_SendData.GetLength();
 CByteArray m_Array;
 
 m_Array.RemoveAll();
 m_Array.SetSize(Count);
 
 for(i=0;i  m_Array.SetAt(i,m_SendData[i]);
 m_MSComm.SetOutput(COleVariant(m_Array));
}

收数据:给串口控件添加消息 
void CTest_mscommDlg::OnOnCommMscomm() 
{
 VARIANT m_input;
 char *str,*str1;
 int k,nEvent,i;
 CString str2,m_RcvData;
 nEvent=m_MSComm.GetCommEvent();
 switch(nEvent)
 {
 case 2:
  k=m_MSComm.GetInBufferCount();     //
接收缓冲区的字符数目
  if(k>0)
  {
   m_input=m_MSComm.GetInput();
   str=(char*)(unsigned char*)m_input.parray->pvData;
  }
  i=0;
  str1=str;
  while(i  {
   i++;
   str1++;
  }
  *str1='{post.content}';                              
  str2=(const char*)str;             //
清除字符串中的不必要字符
  m_RcvData=(const char *)str;
 }
 //
数据显示处理
m_disp+=m_RcvData;
UpdateData(false);

 
}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值