VS2008高版本VC使用微软串口控件mscomm小结

在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是不定的,因此需要自己写一个接收处理(如判断帧头、帧尾、累计长度)。




  • 1
    点赞
  • 8
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值