先说一下,vs6下的代码接口与vs2003和vs2005下是不一样的。
基本上,vs6下面的SetXXX都要变成put_xxx,比如:
SetOutput -> put_Output.(参数为variant类型)
同样GetXXX -> get_XXXX
比如:GetPortOpen ->get_PortOpen.
==========================
1.在界面上加入:microsft communications controls. (mscomm,mscomm32.ocx)
2.对这个空间添加变量,自动生成mscomm.h/mscomm.cpp或者commctrl.h/commctrl.cpp,
一般取名为m_com
3.初始化串口:选择、设置、打开串口
//vs6:
void CCommWizardDlg::OpenPort()
{
if(m_Com.GetPortOpen())
m_Com.SetPortOpen(FALSE);
m_Com.SetCommPort(m_nPort); //选择com1
if( !m_Com.GetPortOpen())
m_Com.SetPortOpen(TRUE);//打开串口
else
AfxMessageBox("cannot open serial port");
m_Com.SetSettings(m_strSettings); //波特率9600,无校验,8个数据位,1个停止位
m_Com.SetRThreshold(1);
//参数1表示每当串口接收缓冲区中有多于或等于1个字符时将引发一个接收数据的OnComm事件
m_Com.SetInputMode(1);
m_Com.SetInputLen(0); //设置当前接收区数据长度为0
m_Com.GetInput();//先预读缓冲区以清除残留数据
}
//vs2003/vs2005
bool CSerialSettingDialog::OpenPort(void)
{
UpdateData(TRUE);
if(m_Com.get_PortOpen())
m_Com.put_PortOpen(FALSE);
m_Com.put_CommPort(atoi(m_strComName.Right(1).GetBuffer(0))); //选择com1
if( !m_Com.get_PortOpen())
m_Com.put_PortOpen(TRUE);//打开串口
else
{
AfxMessageBox("cannot open serial port");
return false;
}
CString strput_tings;
strput_tings = m_strComRate;
strput_tings +=",n";
strput_tings +="," + m_strComData;
strput_tings +="," + m_strComStop;
m_Com.put_Settings(strput_tings); //波特率9600,无校验,8个数据位,1个停止位
m_Com.put_RThreshold(1);
//参数1表示每当串口接收缓冲区中有多于或等于1个字符时将引发一个接收数据的OnComm事件
m_Com.put_InputMode(1);
m_Com.put_InputLen(0); //设置当前接收区数据长度为0
m_Com.get_Input();//先预读缓冲区以清除残留数据
return true;
}
4.收发数据:
////vs6:发
// TODO: Add your control notification handler code here
CString strSend;
if(m_nInputMode > 1) /////字符ascii模式
{
CByteArray hexdata;
int len=String2Hex(m_strSendString ,hexdata);
m_Com.SetOutput(COleVariant(hexdata));
}
else
m_Com.SetOutput(COleVariant(m_strSendString));//发送数据,十六进制模式
////vs6:收,
其实就是通过中断来的,所以需要在控件上通过class wizard或者属性添加事件响应函数:
void CCommWizardDlg::OnOnCommCommctrl()
{
// TODO: Add your control notification handler code here
VARIANT variant_inp;
COleSafeArray safearray_inp;
LONG len,k;
BYTE rxdata[2048]; //设置BYTE数组 An 8-bit integerthat is not signed.
CString strtemp;
if(bReceive)
{
if(m_Com.GetCommEvent()==2) //事件值为2表示接收缓冲区内有字符
{
variant_inp = m_Com.GetInput(); //读缓冲区
safearray_inp = variant_inp; //VARIANT型变量转换为ColeSafeArray型变量
len=safearray_inp.GetOneDimSize(); //得到有效数据长度
for(k=0;k safearray_inp.GetElement(&k,rxdata+k);//转换为BYTE型数组
for(k=0;k {
BYTE bt=*(char*)(rxdata+k); //字符型
if(m_nInputMode == 2)
strtemp.Format("%02X ",bt); //将字符以十六进制方式送入临时变量strtemp存放,注意这里加入一个空隔
else
strtemp.Format("%c",bt); //将字符送入临时变量strtemp存放
m_strReceive = m_strReceive + strtemp; //加入接收编辑框对应字符串
}
m_strReceive += "\r\n";
}
}
UpdateData(FALSE); //更新编辑框内容
}
vs2003/vs2005:
void CSerialSettingDialog::OnCommCommctrl()
{
// TODO: 在此处添加消息处理程序代码
// TODO: Add your control notification handler code here
VARIANT variant_inp;
COleSafeArray safearray_inp;
LONG len,k;
BYTE rxdata[2048]; //设置BYTE数组 An 8-bit integerthat is not signed.
CString strtemp;
if(m_bReceive)
{
if(m_Com.get_CommEvent()==2) //事件值为2表示接收缓冲区内有字符
{
variant_inp = m_Com.get_Input(); //读缓冲区
safearray_inp = variant_inp; //VARIANT型变量转换为ColeSafeArray型变量
len=safearray_inp.GetOneDimSize(); //得到有效数据长度
for(k=0;k safearray_inp.GetElement(&k,rxdata+k);//转换为BYTE型数组
for(k=0;k {
BYTE bt=*(char*)(rxdata+k); //字符型
//if(m_nInputMode == 2)
strtemp.Format("%02X ",bt); //将字符以十六进制方式送入临时变量strtemp存放,注意这里加入一个空隔
//else
// strtemp.Format("%c",bt); //将字符送入临时变量strtemp存放
m_strReceive = m_strReceive + strtemp; //加入接收编辑框对应字符串
}
//m_strReceive += "\r\n";
}
}
UpdateData(FALSE);