现在要用串口编程,要用到CMSComm类,可我不清楚该怎么用,在帮助文档里也找不到,所以向各位大人求救了!
解决方案 »
- 求教:多台数据采集器与服务器的通讯连接采用长连接还是短连接比较合适?
- 不知道是哪里出错
- win7 和xp下运行vs2003不同的吗?
- 如何得到chtmlview弹出对话框 内容
- RegisterClass会重复注册类么?
- 码流分析软件,每一帧图像在坐标轴里用一个矩形显示
- 子窗口弹出一个上下文菜单,如何在父窗口中响应菜单项??
- 高分,“网页取证”怎样做??
- 麻烦一下各位!谢谢!!
- 各位可以交流教授一下源代码的分析方法(一般方法)吗?易者分析一小段程序,难者分析mfc...
- 谁能告诉我vc中ilk和ild文件的作用是什么?删除他们会影响编译吗?
- 各位GG\MM:请问我的MSHFlexGrid为什么鼠标一点,它就闪一下?
使用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); //选择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);// 控件事件的响应声明
// *.h
//{{AFX_MSG(CGolfView)
afx_msg BOOL OnComm();
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_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;
}
for(k=0; k<recd.GetLength(); k++)
{
if(recd.GetAt(k) == ' ')
pace++;
} if( pace == 7)
{
if(m_MyData.Getput(recd)==FALSE) // 从接受的CString recd中获取绘图需要的参数
m_MSComm.SetOutBufferCount(0); // 从串口读取数据失败
wid=m_MyData.CalculationData(); // 正确接受数据,进行计算
SetScrollSizes(); // 更新窗口图象
OnFilePrint(); // 打印图象
recd.Empty(); // 清空保存的字符串
pace = 0; // 空格计数器清零
}
// UpdateData(TRUE);
break; default: // 传输事件出错
m_MSComm.SetOutBufferCount(0);
break;
}
UpdateData(FALSE); //更新图象内容
return TRUE;
}