(1) 使用Vitual Serial Port工具测时,收发数据没问题
(2) 与STM32开发板通信时,只能发数据,接收数据时由于触发不了OnComm事件,所以接收不到数据
(3) 将串口转USB模块的TX与RX短接测试时,串口终端可发数据,但不会触发OnComm事件。
不知道怎么解决这个问题?
OnCommon事件我是在添加msmcomm控件时创建的。这部分应该没问题的。
部分代码附录如下:
void CTerminalDlg::OnCbnSelchangeCombo1()
{
// TODO: 在此添加控件通知处理程序代码
// TODO: 在此添加控件通知处理程序代码
int nSel;
nSel = m_comboCom.GetCurSel();//获取组合框控件的列表框中选中项的索引
m_CtrlComm.put_CommPort(nSel+1);//选择串口号(这里因为列表框的索引号是从0开始,所以(nSel+1)对应的才是我们所选的串口号)
//设置串口
m_CtrlComm.put_InBufferSize(1024); //接收缓存区大小
m_CtrlComm.put_OutBufferSize(1024); //发送缓存区大小
m_CtrlComm.put_InputLen(0); //设置当前接收区数据长度为0
m_CtrlComm.put_InputMode(1);//输入模式选为二进制
m_CtrlComm.put_RThreshold(1); //参数1表示每当串口接收缓冲区中有多于或等于1个字符时将引发一个接收数据的OnComm事件
m_CtrlComm.put_Settings(_T("115200,n,8,1"));//设置串口参数,波特率,无奇偶校验,位停止位,位数据位
m_CtrlComm.put_PortOpen(TRUE);//打开串口
if(m_CtrlComm.get_PortOpen())
{
//点亮指示灯
m_cstatSerial.SetIcon(m_hIconLedON);
m_setOK = true; //标记串口设置OK
}
else
MessageBox(_T("串口打开失败!"));
}
BEGIN_EVENTSINK_MAP(CTerminalDlg, CDialogEx)
ON_EVENT(CTerminalDlg, IDC_MSCOMM, 1, CTerminalDlg::OnCommMscomm, VTS_NONE)
END_EVENTSINK_MAP()
void CTerminalDlg::OnCommMscomm()
{
// TODO: 在此处添加消息处理程序代码
VARIANT variant_inp; //Variant 是一种特殊的数据类型,除了定长String数据及用户定义类型外,可以包含任何种类的数据。
COleSafeArray safearray_inp;
LONG len,k;
BYTE rxdata[2048]; //设置BYTE数组 An 8-bit integer that is not signed.
CString strtemp;
if(m_CtrlComm.get_CommEvent() == CMscomm::comEvReceive) //事件值为2表示接收缓冲区内有字符
{
////////以下你可以根据自己的通信协议加入处理代码
variant_inp = m_CtrlComm.get_Input(); //读缓冲区
safearray_inp = variant_inp; //VARIANT型变量转换为ColeSafeArray型变量
len = safearray_inp.GetOneDimSize(); //得到有效数据长度
for(k=0;k<len;k++)
safearray_inp.GetElement(&k,rxdata+k);//转换为BYTE型数组
for(k=0;k<len;k++) //将数组转换为Cstring型变量
{
BYTE bt = *(char*)(rxdata+k);//字符型
strtemp.Format(_T("%c"),bt); //将字符送入临时变量strtemp存放
m_strRXData += strtemp; //加入接收编辑框对应字符串
}
m_strRXData += _T("\r\n"); //显示完数据后自动换行
}
UpdateData(FALSE); //更新编辑框内容
}
void CTerminalDlg::OnBnClickedBtnSend()
{
// TODO: 在此添加控件通知处理程序代码
if (m_setOK == true) //判断是否打开并初始化串口
{
UpdateData(TRUE); //读取编辑框内容
m_CtrlComm.put_Output(COleVariant(m_strTXData)); //发送数据
m_strTXData.Empty(); //清空输入框
UpdateData(FALSE); //更新输入框内容
}
else
{
MessageBox(_T("请先选择COM口"));
}
}
4 个解决方案
#1
程序我看了下没有问题 你是自发自收测试的吗 你用串口助手看看能不能收到 加断点在接受函数那边 缓冲区有数据会自动触发接收函数
#2
加断点调试过了,用串口调试助手测没有问题的,但是单片机发数据就是触发不了OnComm事件
#3
通过调试发现,将串口模块的TX与RX短接,发送数据时,可以进入到OnCommMscomm()函数,即可以触发接收数据事件,但执行到这行语句: variant_inp = m_CtrlComm.get_Input(); //读缓冲区
系统就会自动退出,并抛出两个异常,情况和下面一样:
当我将该软件在别人机器上面测试时又可以正常收发数据,好奇怪呀?
系统就会自动退出,并抛出两个异常,情况和下面一样:
当我将该软件在别人机器上面测试时又可以正常收发数据,好奇怪呀?
#4
重装系统试试
#1
程序我看了下没有问题 你是自发自收测试的吗 你用串口助手看看能不能收到 加断点在接受函数那边 缓冲区有数据会自动触发接收函数
#2
加断点调试过了,用串口调试助手测没有问题的,但是单片机发数据就是触发不了OnComm事件
#3
通过调试发现,将串口模块的TX与RX短接,发送数据时,可以进入到OnCommMscomm()函数,即可以触发接收数据事件,但执行到这行语句: variant_inp = m_CtrlComm.get_Input(); //读缓冲区
系统就会自动退出,并抛出两个异常,情况和下面一样:
当我将该软件在别人机器上面测试时又可以正常收发数据,好奇怪呀?
系统就会自动退出,并抛出两个异常,情况和下面一样:
当我将该软件在别人机器上面测试时又可以正常收发数据,好奇怪呀?
#4
重装系统试试