【ESP32】HardwareSerial库使用

简介

HardwareSerial 库是c++编写的,应用于esp32 Arduino应用环境的串口驱动库,我们在安装好ESP32的Arduino开发环境后就已经集成了这个串口操作库,在实际应用时直接引用就可以了。

注意:ESP32共有3个UART端口, 其中UART1用于Flash读/写,我们使用串口1时需要注意,需要将串口1映射到其他GPIO上即可,我测试了一下GPIO12、GPIO13,使用串口1时可以完美运行

串口名Arduino名TXRX
UART0Serialpin1pin3
UART1Serial1pin10pin9
UART2Serial2pin17pin16

效果演示

demo程序,将串口0接收到的数据传个串口1,再将串口1接受到的数据传输得串口0

#include <Arduino.h>

#define SERIAL_BAUD 115200

HardwareSerial cardSerial(1);//声明串口1

int distance = 0;

void setup() {
  //初始化串口0
  Serial.begin(SERIAL_BAUD);
  //初始化串口1
  cardSerial.begin(SERIAL_BAUD,SERIAL_8N1,12,13);
  //初始化串口2
  Serial2.begin(SERIAL_BAUD);
}

void loop() {
   while (cardSerial.available() > 0) {
        uint8_t byteFromSerial = cardSerial.read();
        Serial.write(byteFromSerial);
    }
    while (Serial.available() > 0) {
        uint8_t byteFromSerial1 = Serial.read();
        cardSerial.write(byteFromSerial1);
    }
}

在这里插入图片描述

上图中通过HardwareSerial库实现了对串口1的使用,具体说明见下文。

API函数详细说明

使用HardwareSerial库需要先声明一个对象,例如上文图中的HardwareSerial mySerial1(1);;
HardwareSerial类在声明对象时接收一个输入参数(0、1、2),分别代表Serial、Serial1、Serial2;
声明对象后就可以按一般串口的方法使用了,方法说明如下:

初始化串口
void HardwareSerial::begin(unsigned long baud, uint32_t config=SERIAL_8N1, int8_t rxPin=-1, int8_t txPin=-1, bool invert=false, unsigned long timeout_ms = 20000UL);

使能串口,参数如下:

  • baud:串口波特率,该值写0则会进入自动侦测波特率程序;
  • config:串口参数,默认SERIAL_8N1为8位数据位、无校验、1位停止位;
  • rxPin:接收管脚针脚号;
  • txPin:发送管脚针脚号;
  • invert:翻转逻辑电平,串口默认高电平为1、低电平为0;
  • timeout_ms:自动侦测波特率超时时间,如果超过该时间还未获得波特率就不会使能串口;
关闭串口
void HardwareSerial::end();

失能串口,释放资源;

重新设置波特率
void updateBaudRate(unsigned long baud);
设置接收缓存区大小
size_t HardwareSerial::setRxBufferSize(size_t new_size)

设置接收缓存大小(默认为256字节);
ESP32默认有128字节的硬件RX FIFO,在RX FIFO收到数据后会移送到上面的接收缓存中;

返回接收缓存数据长度
int HardwareSerial::available(void);
返回发送缓存区可写长度
int HardwareSerial::availableForWrite(void);

ESP32默认有128字节的硬件TX FIFO,该方法返回TX FIFO空闲字节数;

读取接收缓存区一个字节数据(1)
int HardwareSerial::peek(void);

返回接收缓存中第一个字节数据,但并不从中删除它;

读取接收缓存区一个字节数据(2)
int HardwareSerial::read(void);

返回接收缓存中第一个字节数据,读取过的数据将从接收缓存中清除;

等待串口收发完毕
void HardwareSerial::flush();
发送数据
size_t HardwareSerial::write(uint8_t c)
size_t HardwareSerial::write(const uint8_t *buffer, size_t size)

写数据到TX FIFO,在发送FIFO中的数据会自动输出到TX端口上;
该方法有很多重载,可以用来发送字符串、长整型、整形;
如果TX FIFO已满,则该方法将阻塞;

返回当前串口波特率
uint32_t  HardwareSerial::baudRate()
日志输出设置
void HardwareSerial::setDebugOutput(bool en);

设置该串口打印Debug信息(默认为0,失能后也会置为0);

除上面方法外,因为继承自Stream类所以也可以用该类的方法:如size_t readBytes(char *buffer, size_t length);和size_t readBytes(uint8_t *buffer, size_t length)等。
在这里插入图片描述

  • 5
    点赞
  • 49
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值