pcommlite串口通讯库使用

MFC下串口编程使用最多的两种方法是读取注册表和使用mscomm组件,都有着或多或少的缺陷,调用系统SDK比较麻烦,而MSCOMm组件最多支持16个串口,串口号大于16的时候无法打开,遇到这种情况,可以使用一个名为pcommlite的串口通讯库,下载安装之后,解压出来的文件包括

根据编译的平台选择相应的lib文件加入工程,并加入pcomm.h文件

  1. 寻找系统串口,sio_open()打开串口 sio_close()关闭串口
  2. BYTE i = 0;
  3. CString str;
  4. // TODO: 在此添加控件通知处理程序代码
  5. ((CComboBox *)this->GetDlgItem(IDC_COMBO_Serial_Num_Select))->ResetContent();
  6. for (i = 0;i < 255;i++)
  7. {//此程序支持255个串口
  8. if(SIO_OK == sio_open(i))
  9. {
  10. sio_close(i);
  11. str.AppendFormat("COM%d",i);
  12. ((CComboBox *)GetDlgItem(IDC_COMBO_Serial_Num_Select))->AddString(str);
  13. str.Empty();
  14. }
  15. }
  16. i = ((CComboBox *)GetDlgItem(IDC_COMBO_Serial_Num_Select))->GetCount();
  17. if(i ==0)
  18. {
  19. GetDlgItem(IDC_BUTTON_SERIAL_CONTROL)->EnableWindow(FALSE);
  20. }
  21. else
  22. {
  23. GetDlgItem(IDC_BUTTON_SERIAL_CONTROL)->EnableWindow(TRUE);
  24. }

2.打开串口,各种库宏定义

switch(comBaud)

{

case 0:

m_comBaud = B1200;

break;

case 1:

m_comBaud = B2400;

break;

case 2:

m_comBaud = B4800;

break;

case 3:

m_comBaud = B9600;

break;

case 4:

m_comBaud = B19200;

break;

case 5:

m_comBaud = B38400;

break;

case 6:

m_comBaud = B57600;

break;

case 7:

m_comBaud = B115200;

break;

case 8:

m_comBaud = B230400;

break;

}

switch(comStopBit)

{

case 0:

m_comStopBit = STOP_1;

break;

case 1:

m_comStopBit = STOP_2;

break;

}

switch (comDataLength)

{

case 0:

m_comDataLength = BIT_5;

break;

case 1:

m_comDataLength = BIT_6;

break;

case 2:

m_comDataLength = BIT_7;

break;

case 3:

m_comDataLength = BIT_8;

break;

}

switch(comCheckSum)

{

case 0:

m_comChecksum = P_NONE;

break;

case 1:

m_comChecksum = P_ODD;

break;

case 2:

m_comChecksum = P_EVEN;

break;

}

config = m_comDataLength|m_comStopBit|m_comChecksum;

//开始串口配置

if( sio_open(m_comPort) != SIO_OK)

{

MessageBox("串口打开失败","提示",MB_OK);

this->serialsIsOpen = false;

m_comPort = 0;

return;

}

sio_flowctrl(m_comPort,0x00);//关闭硬件流控制

sio_lctrl(m_comPort,0x00);//关闭RTS DTR

sio_ioctl(m_comPort,m_comBaud,config);

sio_flush(m_comPort,2);

this->GetDlgItem(IDC_BUTTON_SERIAL_CONTROL)->SetWindowText("关闭串口");

GetDlgItem(IDC_COMBO_Serial_Num_Select)->EnableWindow(FALSE);

GetDlgItem(IDC_COMBO_Serial_Baud_Select)->EnableWindow(FALSE);

GetDlgItem(IDC_COMBO_Serial_Data_Select)->EnableWindow(FALSE);

GetDlgItem(IDC_COMBO_Serial_Parity_Select)->EnableWindow(FALSE);

GetDlgItem(IDC_COMBO_Serial_Stop_Select)->EnableWindow(FALSE);

this->serialsIsOpen = true;

}

3.串口发送数据 sio_lstatus() sio_write()

//检查串口是否打开,打开就发送

if(serialsIsOpen == true)

{

//变量打开了,要去测试串口状态

if(sio_lstatus(m_comPort)>= 0)

{

CString str1;

sendString.Empty();

//没有对\r\n特殊处理

((CEdit*)GetDlgItem(IDC_EDIT3))->GetWindowText(str1);

sendString.AppendFormat("%s",str1);

sio_write(m_comPort,sendString.GetBuffer(),sendString.GetLength());

}

else

{

//说明串口已经丢失

MessageBox("串口丢失,请关闭后重新打开","错误",MB_OK);

}

}

else

{

//说明串口已经丢失

MessageBox("请先打开串口","错误",MB_OK);

}

4.设定定时器,用于串口接收数据

5.在定时器中接收数据 sio_read()

void CLPC1768_PAD_OTG_DebugDlg::SerialsProcessBuffer( void )

{

serialReadTemp.Empty();

if(m_comPort > 0 && this->serialsIsOpen == true)

{

char readBuffer[1024] = {0};

//      sio_flush(m_comPort,1);

int length = sio_read(m_comPort,readBuffer,1024);

if(length > 0)

{

for(int i = 0; i < length; i++)

{

serialReadTemp.AppendChar(readBuffer[i]);

}

}

}

}

该库还有很多借口用于控制DTR RTS等,使用方便,详情查看帮助文档

时间: 2024-08-05 23:41:43

pcommlite串口通讯库使用的相关文章

delphi学习笔记2之动态库调用和串口通讯

串口通讯: Spcomm 控件属性: CommName  :表示COM1,COM2等串口的名字: BaudRate:设定波特率9600,4800等 StartComm StopComm 函数WriteCommData(pDataToWrite: PChar;dwSizeofDataToWrite:Word ): boolean 用于发送一个字符串到写线程,发送成功返回true,发送失败返回false, 执行此函数将立即得到返回值,发送操作随后行. 函数有两个参数,其中 pdatatowrite是

【转】C# 串口操作系列(5)--通讯库雏形

串口是很简单的,编写基于串口的程序也很容易.新手们除了要面对一堆的生僻概念,以及跨线程访问的细节,还有一个需要跨越的难题,就是协议解析,上一篇已经说明了: 一个二进制格式的协议一般包含: 协议头 + 数据段长度 + 数据  + 校验 一个Ascii格式的文本协议,一般包含: 数据头 + 正文 + 数据结束标识 类似的命令可能很多,类似的代码也会重复写很多次.对于我,并不觉得这个有任何难度,但是,很多时候,需要写点类似东西的时候呢,我往往不想写,不是别的,要搭建一个这样的框架,这绝对是个体力活,而

Android通过JNI实现与C语言的串口通讯操作蓝牙硬件模块

一直想写一份技术文档,但因为自感能力有限而无从下笔,近期做了个关于Android平台下实现与C语言的通讯来操作蓝牙模块的项目,中间碰到了很多问题,也在网上查了很多资料,在完毕主要功能后.也有一些人在网上问我一些问题.这里写下这篇文档算是一个阶段性的总结. 假设反响好.兴许将会发上Android Stub与新版Android HAL的学习文档. 因为蓝牙模块是串口通讯机制.使用C语言来訪问,而Android的应用层採用Java.无法直接操作硬件.故使用JNI的技术实现主要功能.Android的JN

串口通讯的代码 。是别人写的 我加了些注释。

// Communication.h: interface for the CCommunication class. // ////////////////////////////////////////////////////////////////////// #if !defined(AFX_COMMUNICATION_H__6CA00576_F088_11D1_89BB_8311A0F2733D__INCLUDED_) #define AFX_COMMUNICATION_H__6CA0

串口通讯

STM32串口通讯有3种形式:轮询(阻塞式).中断.DMA.我不知道中断方式的串口通讯有什么适合的应用场景:每接收/发送一个字节,就要发生一次中断,这对CPU反而是一种浪费.使用Cube HAL,轮询式的串口通讯最简单了,发送和接收数据分别有一个函数: HAL_StatusTypeDef HAL_UART_Transmit(UART_HandleTypeDef *huart, uint8_t *pData, uint16_t Size, uint32_t Timeout); HAL_Status

多机串口通讯

★使用器件 使用了3块80c51的单片机,其中U1为主机控制其他两个从机U2,U3.每个单片机上都有一个数码管用来显示数据.主机上有两个按键KEY_1,KEY_2,分别用来控制不同的从机. ★实现目标 主要实现的目标就是通过写多机通讯来了解他们其中的协议,以及简单协议的写法!本程序主要达到了一下效果,主机可以通过发送命令来控制从机:发送数据给从机.接收从机的数据.然后将从机或者主机显示的数据显示在数码管上. ★协议要求 1.地址:主机的地址设置为0x01,从机1(U3)的地址为0x03,从机2(

串口通讯方式1编程

在上位机上用串口调试助手发送一个字符X,单片机收到字符后返回给上位机"I get X",串口波特率设为9600bps. #include<reg52.h> #define uchar unsigned char unsigned char flag,a,i; uchar code table[]="I get"; void init() { TMOD=0x20;  //设定T1定时器的工作模式2 TH1=0xfd; //T1定时器装初值 TL1=0xfd

(c#2.0)serialPort串口通讯

原文:(c#2.0)serialPort串口通讯 using System; using System.Collections.Generic; using System.ComponentModel; using System.Data; using System.Data.SqlClient; using System.Drawing; using System.Text; using System.Windows.Forms; using System.Configuration; usi

Python 串口通讯

摘要: pyserial module: https://github.com/tbusf/pyserial Python使用pyserial进行串口通信:http://blog.csdn.net/log1100/article/details/54380325 串口通讯的python模块--pySerial :http://blog.csdn.net/dainiao01/article/details/5885122 Parameters for the Serial class ser =