123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176 |
- // @file SerialPort.h
- // @brief 串口通信类头文件
- #ifndef SERIALPORT_H_
- #define SERIALPORT_H_
- #include <Windows.h>
- /** 串口通信类
- *
- * 本类实现了对串口的基本操作
- * 例如监听发到指定串口的数据、发送指定数据到串口
- */
- class CSerialPort
- {
- public:
- CSerialPort(void);
- ~CSerialPort(void);
- public:
- /** 初始化串口函数
- *
- * @param: UINT portNo 串口编号,默认值为1,即COM1,注意,尽量不要大于9
- * @param: UINT baud 波特率,默认为9600
- * @param: char parity 是否进行奇偶校验,'Y'表示需要奇偶校验,'N'表示不需要奇偶校验
- * @param: UINT databits 数据位的个数,默认值为8个数据位
- * @param: UINT stopsbits 停止位使用格式,默认值为1
- * @param: DWORD dwCommEvents 默认为EV_RXCHAR,即只要收发任意一个字符,则产生一个事件
- * @return: bool 初始化是否成功
- * @note: 在使用其他本类提供的函数前,请先调用本函数进行串口的初始化
- * /n本函数提供了一些常用的串口参数设置,若需要自行设置详细的DCB参数,可使用重载函数
- * /n本串口类析构时会自动关闭串口,无需额外执行关闭串口
- * @see:
- */
- bool InitPort(UINT portNo = 1, UINT baud = CBR_9600, char parity = 'N', UINT databits = 8, UINT stopsbits = 1, DWORD dwCommEvents = EV_RXCHAR);
- /** 串口初始化函数
- *
- * 本函数提供直接根据DCB参数设置串口参数
- * @param: UINT portNo
- * @param: const LPDCB & plDCB
- * @return: bool 初始化是否成功
- * @note: 本函数提供用户自定义地串口初始化参数
- * @see:
- */
- bool InitPort(UINT portNo, const LPDCB& plDCB);
- /** 开启监听线程
- *
- * 本监听线程完成对串口数据的监听,并将接收到的数据打印到屏幕输出
- * @return: bool 操作是否成功
- * @note: 当线程已经处于开启状态时,返回flase
- * @see:
- */
- bool OpenListenThread();
- /** 关闭监听线程
- *
- *
- * @return: bool 操作是否成功
- * @note: 调用本函数后,监听串口的线程将会被关闭
- * @see:
- */
- bool CloseListenTread();
- /** 向串口写数据
- *
- * 将缓冲区中的数据写入到串口
- * @param: unsigned char * pData 指向需要写入串口的数据缓冲区
- * @param: unsigned int length 需要写入的数据长度
- * @return: bool 操作是否成功
- * @note: length不要大于pData所指向缓冲区的大小
- * @see:
- */
- bool WriteData(unsigned char* pData, unsigned int length);
- /** 获取串口缓冲区中的字节数
- *
- *
- * @return: UINT 操作是否成功
- * @note: 当串口缓冲区中无数据时,返回0
- * @see:
- */
- UINT GetBytesInCOM();
- /** 读取串口接收缓冲区中一个字节的数据
- * @param: char & cRecved 存放读取数据的字符变量
- * @return: bool 读取是否成功
- * @note:
- * @see:
- */
- bool ReadChar(char& cRecved);
- bool OpenUSB1();
- bool CloseUSB1();
- bool OpenUSB2();
- bool CloseUSB2();
- private:
- /** 打开串口
- *
- *
- * @param: UINT portNo 串口设备号
- * @return: bool 打开是否成功
- * @note:
- * @see:
- */
- bool openPort(UINT portNo);
- /** 关闭串口
- *
- *
- * @return: void 操作是否成功
- * @note:
- * @see:
- */
- void ClosePort();
- /** 串口监听线程
- *
- * 监听来自串口的数据和信息
- * @param: void * pParam 线程参数
- * @return: UINT WINAPI 线程返回值
- * @note:
- * @see:
- */
- static UINT WINAPI ListenThread(void* pParam);
- private:
- /** 串口句柄 */
- HANDLE m_hComm;
- /** 线程退出标志变量 */
- static bool s_bExit;
- /** 线程句柄 */
- volatile HANDLE m_hListenThread;
- /** 同步互斥,临界区保护 */
- CRITICAL_SECTION m_csCommunicationSync; //!< 互斥操作串口
- };
- #endif //SERIALPORT_H_```
|