3.串口初始化:
m_Comm.SetCommPort(1); m_Comm.SetInputMode(1); m_Comm.SetSettings("9600,n,8,1"); m_Comm.SetRThreshold(1); m_Comm.SetInputLen(0); if(!m_Comm.GetPortOpen()) { m_Comm.SetPortOpen(TRUE); } else AfxMessageBox(“Open The Serial Port 1 Failurre!”); m_Comm.GetInput(); |
4.串口接收数据初始化:
MSComm 控件采用查询或事件驱动的方式从端口获取数据。这里采用事件驱动法完成对端口数据的监视和处理:有事件发生(串口接收到数据)时通知程序,并及时的捕获和处理这个通讯事件。
在MscommDemoView.h中添加事件驱动说明:
protected: afx_msg void OnComm();
DECLARE_EVENTSINK_MAP() |
在 MscommDemoView.cpp 中添加事件的驱动:
BEGIN_EVENTSINK_MAP(CMscommDemoView, CView)
//{{AFX_EVENTSINK_MAP(CAboutDlg)
ON_EVENT(CMscommDemoView,IDC_MSCOMM,1,OnComm,VTS_NONE)
//}}AFX_EVENTSINK_MAP
END_EVENTSINK_MAP() |
5.串口数据读写:
MSComm 类的读写函数比较简单:GetInput()和SetOutput()。函数原形分别为VARIANT GetInput()和void SetOutput(const VARIANT newValue),均使用VARIANT类型。但PC机发送和接收数据时习惯用字符串形式。MSDN中查阅VARIANT类型,可以用BSTR表示字符串,但所有的BSTR都包含宽字符,而只有Windows NT支持宽字符,Windows 9X并不支持。所以要完成一个适应各平台的串口应用程序必须解决这个问题。这里使用CbyteArray即可解决之。
添加事件响应函数CMscommDemoView::OnComm()
//接收数据 void CMscommDemoView::OnComm() { VARIANT m_input; char *str,*str1; int k,nEvent,i; CString str2,m_RcvData; nEvent=m_Comm.GetCommEvent(); switch(nEvent) { case 2: k=m_Comm.GetInBufferCount(); //接收缓冲区的字符数目 if(k>0) { m_input=m_Comm.GetInput(); str=(char*)(unsigned char*)m_input.parray->pvData; } i=0; str1=str; while(i<k) { i++; str1++; } *str1=''''\0''''; str2=(const char*)str; //清除字符串中的不必要字符 m_RcvData=(const char *)str; } //数据显示处理 }
//发送数据
void CMscommDemoView::SendData() { 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<Count;i++) m_Array.SetAt(i,m_SendData[i]); m_Comm.SetOutput(COleVariant(m_Array)); } |
以上只是MSComm控件在基于单文档的工程中的初步框架。程序在Win2000+VC6.0下调试通过。欢迎大家讨论。
|