在VS2008中使用mscomm的文章有很多,这里把关键的几处小结一下:
1. 最好安装一遍VC++6.0,因为mscomm控件在VC6中是自带的。装好了VC6,在VS2008中就可以直接使用mscomm了;如果不想安装VC6的,那么直接到这里下载mscomm控件(http://download.csdn.net/detail/dijkstar/9513049),直接运行里面的批处理文件注册;
2. 在VS2008中使用该控件的方法:选择菜单【工具】--选择工具箱项--COM组件--Microsoft Communications Control,version 6.0;
3. 初始化:
void CTestDlg::OnBnClickedButton1()
{
//添加的对串口的初始化语句
int commNo = 5;
if(m_cComm.get_PortOpen()) //如果发现串口本来是打开的,则关闭串口
m_cComm.put_PortOpen(FALSE);
m_cComm.put_CommPort(commNo); //选择COM1端口
m_cComm.put_InputMode(1); //输入方式为二进制方式
m_cComm.put_InBufferSize(1024); //设置输入缓冲区
m_cComm.put_OutBufferSize(512); //设置输出缓冲区
m_cComm.put_Settings(TEXT("9600,n,8,1"));//波特率,无校验,个数据位,个停止位
if(!m_cComm.get_PortOpen())
{
m_cComm.put_PortOpen(TRUE); //打开串口
m_cComm.put_RThreshold(1); //每当接收缓冲区有个字符则接收串口数据
m_cComm.put_InputLen(0); //设置当前缓冲区长度为m_cComm.get_Input(); //预读缓冲区以清除残留数据
}
else
AfxMessageBox("打开端口失败!",MB_ICONSTOP,0);
}
4. 发送:下面看出,既可以发送“能看的见”的字符串,又可以发送二进制数据,注意CString如何存取unsigned char类型字符的用法,CByteArray就不用多解释了,太直观了。
void CTestDlg::OnBnClickedButton2()
{
m_strRecvData.Empty();
/*
//使用CString代替unsigned char缓冲区
CString m_strSendData = "";
m_strSendData += (unsigned char)0x30;
m_strSendData += (unsigned char)0x08;
m_strSendData += (unsigned char)0x0a;
m_strSendData += (unsigned char)0x33;
m_cComm.put_Output(COleVariant(m_strSendData));//发送数据
*/
//直接使用CByteArray
CByteArray array;
array.Add(0x30);
array.Add(0x08);
array.Add(0x0A);
array.Add(0x9F);
m_cComm.put_Output(COleVariant(array));//发送数据
}
5. 接收:因为是在该控件的事件中处理的(在该控件上单击右键添加处理事件)
void CTestDlg::OnComm()
{
//从串口接收数据并显示在编辑框中
VARIANT variant_inp;
COleSafeArray safearray_inp;
long len,k;
byte rxdata[512]; //设置BYTE数组
CString strtemp;
unsigned char *buf = NULL;
if(m_cComm.get_CommEvent()==2) //值为表示接收缓冲区内有字符
{
len=m_cComm.get_InBufferCount(); //得到有效的数据长度
variant_inp=m_cComm.get_Input(); //读缓冲区消息
//开始使用收到的数据.........
TRACE("Len= %d\t", len);
buf = (unsigned char*)variant_inp.parray->pvData;
for (int i=0; i<len; i++)
{
TRACE("0x%02x ", (unsigned char )buf[i]);
}
TRACE("\r\n");
/*
//另外一种使用方式
safearray_inp=variant_inp; ///变量转换
len=safearray_inp.GetOneDimSize(); //得到有效的数据长度
for(k=0;k<len;k++)
safearray_inp.GetElement(&k, rxdata+k);
TRACE("len = %d\r\n", len); //打印每次收到的个数
for(k=0;k<len;k++) //将数组转换为CString型变量
{
char bt=*(char*)(rxdata+k); //字符型
strtemp.Format("0x%02x ",bt); //将字符送入临时变量strtemp存放
m_strRecvData += strtemp; //加入接收编辑框对应字符串
}
*/
}
}
上述直接使用未注释的代码,因为已经得到了数据的长度len,和指针buf,剩下来自己用吧。还有注意的是每次收到的长度len是不定的,因此需要自己写一个接收处理(如判断帧头、帧尾、累计长度)。