SerialPort.h 3.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176
  1. // @file SerialPort.h
  2. // @brief 串口通信类头文件
  3. #ifndef SERIALPORT_H_
  4. #define SERIALPORT_H_
  5. #include <Windows.h>
  6. /** 串口通信类
  7. *
  8. * 本类实现了对串口的基本操作
  9. * 例如监听发到指定串口的数据、发送指定数据到串口
  10. */
  11. class CSerialPort
  12. {
  13. public:
  14. CSerialPort(void);
  15. ~CSerialPort(void);
  16. public:
  17. /** 初始化串口函数
  18. *
  19. * @param: UINT portNo 串口编号,默认值为1,即COM1,注意,尽量不要大于9
  20. * @param: UINT baud 波特率,默认为9600
  21. * @param: char parity 是否进行奇偶校验,'Y'表示需要奇偶校验,'N'表示不需要奇偶校验
  22. * @param: UINT databits 数据位的个数,默认值为8个数据位
  23. * @param: UINT stopsbits 停止位使用格式,默认值为1
  24. * @param: DWORD dwCommEvents 默认为EV_RXCHAR,即只要收发任意一个字符,则产生一个事件
  25. * @return: bool 初始化是否成功
  26. * @note: 在使用其他本类提供的函数前,请先调用本函数进行串口的初始化
  27. *      /n本函数提供了一些常用的串口参数设置,若需要自行设置详细的DCB参数,可使用重载函数
  28. * /n本串口类析构时会自动关闭串口,无需额外执行关闭串口
  29. * @see:
  30. */
  31. bool InitPort(UINT portNo = 1, UINT baud = CBR_9600, char parity = 'N', UINT databits = 8, UINT stopsbits = 1, DWORD dwCommEvents = EV_RXCHAR);
  32. /** 串口初始化函数
  33. *
  34. * 本函数提供直接根据DCB参数设置串口参数
  35. * @param: UINT portNo
  36. * @param: const LPDCB & plDCB
  37. * @return: bool 初始化是否成功
  38. * @note: 本函数提供用户自定义地串口初始化参数
  39. * @see:
  40. */
  41. bool InitPort(UINT portNo, const LPDCB& plDCB);
  42. /** 开启监听线程
  43. *
  44. * 本监听线程完成对串口数据的监听,并将接收到的数据打印到屏幕输出
  45. * @return: bool 操作是否成功
  46. * @note: 当线程已经处于开启状态时,返回flase
  47. * @see:
  48. */
  49. bool OpenListenThread();
  50. /** 关闭监听线程
  51. *
  52. *
  53. * @return: bool 操作是否成功
  54. * @note: 调用本函数后,监听串口的线程将会被关闭
  55. * @see:
  56. */
  57. bool CloseListenTread();
  58. /** 向串口写数据
  59. *
  60. * 将缓冲区中的数据写入到串口
  61. * @param: unsigned char * pData 指向需要写入串口的数据缓冲区
  62. * @param: unsigned int length 需要写入的数据长度
  63. * @return: bool 操作是否成功
  64. * @note: length不要大于pData所指向缓冲区的大小
  65. * @see:
  66. */
  67. bool WriteData(unsigned char* pData, unsigned int length);
  68. /** 获取串口缓冲区中的字节数
  69. *
  70. *
  71. * @return: UINT 操作是否成功
  72. * @note: 当串口缓冲区中无数据时,返回0
  73. * @see:
  74. */
  75. UINT GetBytesInCOM();
  76. /** 读取串口接收缓冲区中一个字节的数据
  77. * @param: char & cRecved 存放读取数据的字符变量
  78. * @return: bool 读取是否成功
  79. * @note:
  80. * @see:
  81. */
  82. bool ReadChar(char& cRecved);
  83. bool OpenUSB1();
  84. bool CloseUSB1();
  85. bool OpenUSB2();
  86. bool CloseUSB2();
  87. private:
  88. /** 打开串口
  89. *
  90. *
  91. * @param: UINT portNo 串口设备号
  92. * @return: bool 打开是否成功
  93. * @note:
  94. * @see:
  95. */
  96. bool openPort(UINT portNo);
  97. /** 关闭串口
  98. *
  99. *
  100. * @return: void 操作是否成功
  101. * @note:
  102. * @see:
  103. */
  104. void ClosePort();
  105. /** 串口监听线程
  106. *
  107. * 监听来自串口的数据和信息
  108. * @param: void * pParam 线程参数
  109. * @return: UINT WINAPI 线程返回值
  110. * @note:
  111. * @see:
  112. */
  113. static UINT WINAPI ListenThread(void* pParam);
  114. private:
  115. /** 串口句柄 */
  116. HANDLE m_hComm;
  117. /** 线程退出标志变量 */
  118. static bool s_bExit;
  119. /** 线程句柄 */
  120. volatile HANDLE m_hListenThread;
  121. /** 同步互斥,临界区保护 */
  122. CRITICAL_SECTION m_csCommunicationSync; //!< 互斥操作串口
  123. };
  124. #endif //SERIALPORT_H_```