VS 2010中使用MSCOMM串口控件实现串口通信

来源:互联网 发布:linux如何查找文件 编辑:程序博客网 时间:2024/04/29 05:02

    注意:Mscomm控件在VC6.0里面生成的类和VS2010里面生成的类不一样。准确的说是封装的操作名字和使用方式有点不一样。

以对话框程序为例,下面试着在vs2010下使用该控件(控件在使用之前必须要注册)。

第一步:

       创建对话框程序,画好编辑框等控件。

第二步:

       插入MSCOMM控件,添加控件相关的类。并为控件添加好变量。

第三步:

       添加消息处理函数,这里要注意的是MSCOMM控件的响应函数要右击控件选择添加事件处理函数,消息类型选择为OnComm类型。

下面是各个函数的实现:

[cpp] view plain copy
  1. //发送按钮按下响应函数  
  2. void CCommTeatDlg::OnBnClickedButton3()  
  3. {  
  4.     UpdateData(TRUE);  
  5.     m_mscomm.put_Output(COleVariant(m_EditSend));//向串口下发数据  
  6.     m_EditSend.Empty();//将编辑框内容清空  
  7.     UpdateData(FALSE);  
  8. }  

[cpp] view plain copy
  1. void CCommTeatDlg::OnBnClickedButton2()  
  2. {  
  3.     m_mscomm.put_PortOpen(FALSE);//关闭串口  
  4.     AfxMessageBox(_T("串口已关闭"));//显示提示窗口  
  5. }  

[cpp] view plain copy
  1. void CCommTeatDlg::OnBnClickedButton1()  
  2. {  
  3.     if(m_mscomm.get_PortOpen())//检测串口是否已经打开  
  4.     {  
  5.         m_mscomm.put_PortOpen(FALSE);//若串口已经打开,则关闭串口  
  6.     }  
  7.     m_mscomm.put_CommPort(1);//打开串口1  
  8.     m_mscomm.put_InBufferSize(1024);//串口接收缓冲区大小  
  9.     m_mscomm.put_OutBufferSize(1024);//串口发送缓冲去大小  
  10.     m_mscomm.put_InputLen(0);//数据发送长度  
  11.     m_mscomm.put_InputMode(1);//数据发送模式  
  12.     m_mscomm.put_RThreshold(1);//  
  13.     m_mscomm.put_Settings(_T("4800,n,8,1"));//串口设置  
  14.     if(!m_mscomm.get_PortOpen())//检测串口是否打开,若关闭则打开串口  
  15.     {  
  16.         m_mscomm.put_PortOpen(TRUE);  
  17.         AfxMessageBox(_T("打开串口成功"));  
  18.     }  
  19.     else  
  20.     {  
  21.         m_mscomm.put_OutBufferCount(0);//清空输出缓冲区  
  22.         AfxMessageBox(_T("打开串口失败"));//提示串口打开失败  
  23.     }  
  24. }  

特别注意一下这段:

[cpp] view plain copy
  1. BEGIN_EVENTSINK_MAP(CCommTeatDlg, CDialogEx)  
  2.     ON_EVENT(CCommTeatDlg, IDC_MSCOMM1, 1, CCommTeatDlg::OnCommMscomm1, VTS_NONE)  
  3. END_EVENTSINK_MAP()  




void CCommTeatDlg::OnCommMscomm1()  {   // TODO: 串口消息处理//常数 值 描述 //comEvSend 1 发送事件。 //comEvReceive 2 接收事件。 //comEvCTS 3 clear-to-send 线变化。 //comEvDSR 4 data-set ready 线变化。 //comEvCD 5 carrier detect 线变化。 //comEvRing 6 振铃检测。 //comEvEOF 7 文件结束。 short curEvent =m_com.get_CommEvent();      switch(curEvent)      {      case CMscomm1::comEvReceive:          EvReceiveHandle();  //串口接收处理示例        break;     } }  




//接收到字符处理;void CUSARTDlg::EvReceiveHandle(void)  {  // TODO: 在此处添加消息处理程序代码VARIANT variant_inp;COleSafeArray safearray_inp;LONG len,k;BYTE rxdata[2048]; //设置BYTE数组 An 8-bit integerthat is not signed.CString strtemp;//variant_inp=m_com.get_Input(); //读缓冲区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(_T("%02x"),bt);//将字符送入临时变量strtemp存放     m_RxStr+=strtemp; m_RxStr+=" ";//m_strRXData+=strtemp; //加入接收编辑框对应字符串}SetDlgItemText(IDC_Rx,m_RxStr);}


[cpp] view plain cop


0 0
原创粉丝点击