ImageVerifierCode 换一换
格式:DOC , 页数:7 ,大小:39.50KB ,
资源ID:11799571      下载积分:10 金币
快捷注册下载
登录下载
邮箱/手机:
温馨提示:
快捷下载时,用户名和密码都是您填写的邮箱或者手机号,方便查询和重复下载(系统自动生成)。 如填写123,账号就是123,密码也是123。
特别说明:
请自助下载,系统不会自动发送文件的哦; 如果您已付费,想二次下载,请登录后访问:我的下载记录
支付方式: 支付宝    微信支付   
验证码:   换一换

开通VIP
 

温馨提示:由于个人手机设置不同,如果发现不能下载,请复制以下地址【https://www.zixin.com.cn/docdown/11799571.html】到电脑端继续下载(重复下载【60天内】不扣币)。

已注册用户请登录:
账号:
密码:
验证码:   换一换
  忘记密码?
三方登录: 微信登录   QQ登录  

开通VIP折扣优惠下载文档

            查看会员权益                  [ 下载后找不到文档?]

填表反馈(24小时):  下载求助     关注领币    退款申请

开具发票请登录PC端进行申请

   平台协调中心        【在线客服】        免费申请共赢上传

权利声明

1、咨信平台为文档C2C交易模式,即用户上传的文档直接被用户下载,收益归上传人(含作者)所有;本站仅是提供信息存储空间和展示预览,仅对用户上传内容的表现方式做保护处理,对上载内容不做任何修改或编辑。所展示的作品文档包括内容和图片全部来源于网络用户和作者上传投稿,我们不确定上传用户享有完全著作权,根据《信息网络传播权保护条例》,如果侵犯了您的版权、权益或隐私,请联系我们,核实后会尽快下架及时删除,并可随时和客服了解处理情况,尊重保护知识产权我们共同努力。
2、文档的总页数、文档格式和文档大小以系统显示为准(内容中显示的页数不一定正确),网站客服只以系统显示的页数、文件格式、文档大小作为仲裁依据,个别因单元格分列造成显示页码不一将协商解决,平台无法对文档的真实性、完整性、权威性、准确性、专业性及其观点立场做任何保证或承诺,下载前须认真查看,确认无误后再购买,务必慎重购买;若有违法违纪将进行移交司法处理,若涉侵权平台将进行基本处罚并下架。
3、本站所有内容均由用户上传,付费前请自行鉴别,如您付费,意味着您已接受本站规则且自行承担风险,本站不进行额外附加服务,虚拟产品一经售出概不退款(未进行购买下载可退充值款),文档一经付费(服务费)、不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
4、如你看到网页展示的文档有www.zixin.com.cn水印,是因预览和防盗链等技术需要对页面进行转换压缩成图而已,我们并不对上传的文档进行任何编辑或修改,文档下载后都不会有水印标识(原文档上传前个别存留的除外),下载后原文更清晰;试题试卷类文档,如果标题没有明确说明有答案则都视为没有答案,请知晓;PPT和DOC文档可被视为“模板”,允许上传人保留章节、目录结构的情况下删减部份的内容;PDF文档不管是原文档转换或图片扫描而得,本站不作要求视为允许,下载前可先查看【教您几个在下载文档中可以更好的避免被坑】。
5、本文档所展示的图片、画像、字体、音乐的版权可能需版权方额外授权,请谨慎使用;网站提供的党政主题相关内容(国旗、国徽、党徽--等)目的在于配合国家政策宣传,仅限个人学习分享使用,禁止用于任何广告和商用目的。
6、文档遇到问题,请及时联系平台进行协调解决,联系【微信客服】、【QQ客服】,若有其他问题请点击或扫码反馈【服务填表】;文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“【版权申诉】”,意见反馈和侵权处理邮箱:1219186828@qq.com;也可以拔打客服电话:0574-28810668;投诉电话:18658249818。

注意事项

本文(VC的MSCOMM控件.doc)为本站上传会员【仙人****88】主动上传,咨信网仅是提供信息存储空间和展示预览,仅对用户上传内容的表现方式做保护处理,对上载内容不做任何修改或编辑。 若此文所含内容侵犯了您的版权或隐私,请立即通知咨信网(发送邮件至1219186828@qq.com、拔打电话4009-655-100或【 微信客服】、【 QQ客服】),核实后会尽快下架及时删除,并可随时和客服了解处理情况,尊重保护知识产权我们共同努力。
温馨提示:如果因为网速或其他原因下载失败请重新下载,重复下载【60天内】不扣币。 服务填表

VC的MSCOMM控件.doc

1、MFC之MSCOMM 2010年11月19日星期五 在mfc中进行串口通讯最简单的方法莫过于在对话框中使用MSCOMM控件了,MSComm通信控件提供了一系列标准通信命令的接口,它允许建立串口连接,可以连接到其他通信设备(如Modem).还可以发送命令、进行数据交换以及监视和响应在通信过程中可能发生的各种错误和事件,从而可以用它创建全双工 、事件驱动的、高效实用的通信程序。 一、用MSComm控件通信 1.串口通信基础知识 一般悦来,计算机都有一个或多个串行端口,它们依次为com1、Com2、…,这些串口还提供了外部设备与pC进行数据传输和通信的通道。这些串口在CPU和外设之间充当解

2、释器的角色。当字符数据从CPU发送给外设时,这些字符数据将被转换成串行比特流数据;当接收数据时,比特流数据被转换为字符数据传递给CPU,再进一步说,在操作系统方面,Windows用通信驱动程序(COMM.DRV)调用API函数发送和接收数据,当用通信控件或声明调用API函数时,它门由COMM. DRV解释并传递给设备驱动程序,作为一个程序员,要编写通信程序.只需知道通信控件提供给Windows通信AP1函数的接口即可.换句话说,只需设定和监视通信控件的属性和事件即可。 2.使用Mscomm控件 在开始使用MSComm控件之前。需要先了解其属性、事件或错误 属性              

3、  描述 CommPort       设置或返回通信端口号 Settings          以字符串的形式设置或返回波特率、奇偶校验、数据位和停止位 PortOpen        设置或返回通信端口的状态。也可以打开和关闭端口 Input               返回和删除接收缓冲区中的字符 Output            将字符串写入发送缓冲区 CommEvent属性为通信事件或错误返回下列值之一。在该控件的对象库中也可以找到这些常量。 常量                          值                描述 ComEventBrea

4、k        1001           收到了断开信号 ComEventCTSTO      1002           Clear To Send Timeout。在发送字符时,在系统指定的事1件内,CTS(Clear To end)线是低电平 ComEventDSRTO      1003           Data Set Ready Timeout。在发送字符时,在系统指定的事件内,DSR(Data Set Ready)线是低电平 ComEventFrame       1004           数据帧错误。硬件检测到一个数据帧错误 ComEventOverru

5、n     1006           端口溢出。硬件中的字符尚未读,下一个字符又到达,并且丢失 ComEventCDTO       1007           Carrier Detect Time。在发送字符时,在系统指定的事件内,CD(Carrier Detect)线是低电平。CD 也称为RLSD(Receive Line Singal Detect,接收线信号检测) ComEventRxOver      1008           接收缓冲区溢出。在接收缓冲区中没有空间 ComEventRxParity    1009          奇偶校验错。硬件检测到奇偶校验错

6、误7 ComEventTxFull        1010          发送缓冲区满。在对发送字符排队时,发送缓冲区满 ComEventDCB         1011          检取端口DCB(Device Control Blick)时发生了没有预料到的错误 通信事件包含了下面的设置: 常量                  值         描述 ComEvSend       1         发送缓冲区中的字符数比Sthreshold值低 ComEvReceive    2         接收到了Rthreshold个字符。持续产生该事件,直到使用

7、了Input属性删除了接收缓冲区中的数据 ComEvCTS        3         CTS(Clear To Send)线改变 ComEvDSR        4         DSR(Data Set Ready)线改变。当DSR从1到0改变时,该事件发生 ComEvCD          5          CD(Carrier Detect)线改变ComEvRing6检测到响铃信号。一些URAT(Universal AsynchronousReciver--Transmitters,通用异步收发器)不支持该事件 ComEvEOF        7     收到了EO

8、F字符(ASCII字符26) Error消息(MSComm控件)下表列出了MSComm控件可捕获的错误消息: 常量                                    值       描述 ComInvalidPropertyValue       380    无效的属性值 ComSetNotSupported           383    属性只读 ComGetNotSupported           394    属性只读 ComPortOpen                      8000    端口打开时该存在无效          

9、                                  8001    超时设置必须比0值大 ComPortInvalid                     8002    无效的端口号                                           8003    属性只在运行时有效                                          8004    属性在运行时是只读的 ComPortAleadyOpen           8005    端口已经打开                              

10、             8006    设备标识符无效或不支持                                          8007    不支持设备的波特率                                         8008    指定的字节大小无效                                         8009    缺省参数错误                                         8010    硬件不可用(被其他设备锁住)                            

11、            8011    函数不能分配队列 ComNoOpen                     8012    设备没有打开                                         8013    设备已经打开                                          8014    不能使用通信通知 ComSetCommStateFailed      8015    不能设置通信状态                                              8016    不能设置通信事件屏蔽

12、 ComPortNotOpen                  8018    该存在只在端口打开是有效                                             8019    设备忙 ComReadError                     8020    通信设备读错误 ComDCBError                     8021    检取端口设备控制块时出现内部错误 注意在使用的时候一定要保证两个通讯串口的设置是相同的,否则受到的信息将会产生错误! 由于取值位数的不同,有可能发送的信息要读很多次才能组合成需要的信息! 1

13、建立mfc工程。       将控件加进来:打开“Project->Add To Project->Components and Controls->Registered Activex Controls”,然后选择控件:Microsoft Communication Control,version 6.0插入到当前的工程中。这样就将类 CMSComm 的相关文件 mscomm.cpp 和 mscomm.h 一并加入到了工程中。编程时只需将控件对话中的 MSComm 控件拖至你的应用对话框中就OK了 2。定义串口对象:      CMSComm       m_MSComm; 3。串

14、口初始化:     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_M

15、SComm.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_MSC

16、omm.SetOutBufferCount(0); AfxMessageBox("Open The Serial Port 1 Failurre!"); } 4。串口数据读写:   MSComm 类的读写函数比较简单:GetInput()和SetOutput()。函数原形分别为VARIANT GetInput()和void SetOutput(const VARIANT newValue),均使用VARIANT类型。但PC机发送和接收数据时习惯用字符串形式。MSDN中查阅VARIANT类型,可以用BSTR表示字符串,但所有的BSTR都包含宽字符,而只有Windows NT支持宽字符,W

17、indows 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_Ar

18、ray.RemoveAll(); m_Array.SetSize(Count); for(i=0;i

19、mm.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.c

20、ontent}';                                  str2=(const char*)str;              //清除字符串中的不必要字符    m_RcvData=(const char *)str; } //数据显示处理 m_disp+=m_RcvData; UpdateData(false); } 、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、 @@@@@@@@@@@@@@@@@@@@@@@@@@@@@@ 网上一个家伙的例子 首先,在对话框中创建通信控件,

21、若Control工具栏中缺少该控件,可通过菜单Project --> Add to Project --> Components and Control插入即可,再将该控件从工具箱中拉到对话框中。此时,你只需要关心控件提供的对 Windows 通讯驱动程序的 API 函数的接口。换句话说,只需要设置和监视MSComm控件的属性和事件。   打开所需串口后,需要考虑串口通信的时机。在接收或发送数据过程中,可能需要监视并响应一些事件和错误,所以事件驱动是处理串行端口交互作用的一种非常有效的方法。使用 OnComm 事件和 CommEvent 属性捕捉并检查通讯事件和错误的值。发生通讯事件或错误

22、时,将触发 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_MSC

23、OMM1); 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_MSC

24、omm.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); // 控件事件的响应声明 // *.h //{{AFX_MSG(CGolfView) afx_msg BOOL OnCo

25、mm(); DECLARE_EVENTSINK_MAP() //}}AFX_MSG // *.cpp BEGIN_EVENTSINK_MAP(CGolfView, CView) //{{AFX_EVENTSINK_MAP(CAboutDlg) ON_EVENT(CGolfView, IDC_MSCOMM1, 1 /* OnComm */, OnComm, VTS_NONE) //}}AFX_EVENTSINK_MAP END_EVENTSINK_MAP() // 控件事件的响应 BOOL CGolfView::OnComm() {  VARIANT variant_

26、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);

27、   variant_inp=m_MSComm.GetInput(); //读缓冲区    safearray_inp=variant_inp; //VARIANT型变量转换为ColeSafeArray型变量    len=safearray_inp.GetOneDimSize(); //得到有效数据长度    // 接受数据    for(k=0; k

移动网页_全站_页脚广告1

关于我们      便捷服务       自信AI       AI导航        抽奖活动

©2010-2026 宁波自信网络信息技术有限公司  版权所有

客服电话:0574-28810668  投诉电话:18658249818

gongan.png浙公网安备33021202000488号   

icp.png浙ICP备2021020529号-1  |  浙B2-20240490  

关注我们 :微信公众号    抖音    微博    LOFTER 

客服