一、基本使用
ESP32有三个串口,编号分别为0、1、2。这里不多解释。
输出“hello world”的程序。
解单解释一下,第一部分代码是初始化函数,用来初始化串口并将串口的波特率设置为115200。第二部分是一个死循环函数,我们这里可以将其理解为while(1),他的作用就是让内部的函数一直执行,从而可以达到监视窗口的目的。
然后我们将串口数据的接收和发送程序下载到开发板(详情见上一期)
#include <HardwareSerial.h>
HardwareSerial MySerial_stm32(1);
unsigned short i;
char temp;
//这个函数适用于清理串口读取缓存区的缓存,其实也就是用读一个删除一个的方式清理,我还会打印出有没有进行清理,清理了哪些内容
void clear_usart_buffer(){
i = MySerial_stm32.available();
if(i != 0){
Serial.print("清空串口接收区的缓存......");
Serial.println(MySerial_stm32.available());
while(i--)
MySerial_stm32.read(); //读取串口接收回来的数据但是不做处理只给与打印
}
else
Serial.println("串口接收区的缓存为空!!!");
}
/
void read_usart(){
i = MySerial_stm32.available(); //返回目前串口接收区内的已经接受的数据量
if(i != 0){
Serial.print("串口接收到的数据量为:");
Serial.println(MySerial_stm32.available());
while(i--){
temp = MySerial_stm32.read(); //读取一个数据并且将它从缓存区删除
Serial.print(temp); //读取串口接收回来的数据但是不做处理只给与打印
}
Serial.println("");
//data_analyse(); //至关重要的一步,也就是把读取回来的数据进行分步截取直接拿到我们想要的数据,我下一篇博文会讲如何自己写这个函数
}
else
Serial.println("串口接收区没有数据!!!");
}
void setup() {
Serial.begin(115200);
//串口的开启,这里还可以传一些别的参数,但是我们只传入下面四个最重要的:波特率,默认SERIAL_8N1为8位数据位、无校验、1位停止位,后面两个分别为 RXD,TXD 引脚
MySerial_stm32.begin(115200, SERIAL_8N1, 14, 15);
//MySerial_stm32.updateBaudRate(9600); //重新设置波特率;
//MySerial_stm32.end(); //失能串口,释放占用的资源
clear_usart_buffer(); //清空接收区缓存函数
}
void loop() {
MySerial_stm32.println("usart test!!!");
read_usart();
delay(500);
read_usart();
delay(500);
read_usart();
delay(500);
}
二、存在的问题
使用Serial1(U1TXD=GPIO10,U1RXD=GPIO9)时程序无法正常运行。接收数据时只能接收到一次。这让我很是头疼。后来查阅相关资料后。发现是开发版自身的问题,《ESP32 技术规格书》中明确的写到,ESP32的GPIO6~11一般用于连接外部Flash芯片
但是Serial1默认使用了GPIO9和10,从而导致程序崩溃:
解决方法一
使用另一个串口,但是实际操作后还是不可以。
解决方法二
使用HardwareSerial库
ESP32片上功能模组所发出的信号可映射到任何 GPIO管脚,使用Arduino core for the ESP32中自带的HardwareSerial库就可以将串口RX映射到几乎所有IO口上,TX映射到GPIO0~31上。
代码如下:注意RX接5号IO口,TX接18号IO口。波特率默认115200.
HardwareSerial mySerial1(1);
void setup()
{
mySerial1.begin(115200,SERIAL_8N1,5,18);
}
void loop()
{mySerial1.println("hello world");
dalay(1000);
}
void 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 end();
失能串口,释放资源;
void updateBaudRate(unsigned long baud);
重新设置波特率;
int available(void);
返回接收缓存可读取字节数;
int availableForWrite(void);
ESP32默认有128字节的硬件TX FIFO,该方法返回TX FIFO空闲字节数;
int peek(void);
返回接收缓存中第一个字节数据,但并不从中删除它;
int read(void);
返回接收缓存中第一个字节数据,读取过的数据将从接收缓存中清除;
void flush(void);
等待串口收发完毕;
size_t write(uint8_t);
写数据到TX FIFO,在发送FIFO中的数据会自动输出到TX端口上;
该方法有很多重载,可以用来发送字符串、长整型、整形;
如果TX FIFO已满,则该方法将阻塞;
size_t write(const uint8_t *buffer, size_t size);
写数据到TX FIFO,如果发送FIFO已满,则该方法将阻塞;
uint32_t baudRate();
返回当前串口波特率;
size_t setRxBufferSize(size_t);
设置接收缓存大小(默认为256字节);
ESP32默认有128字节的硬件RX FIFO,在RX FIFO收到数据后会移送到上面的接收缓存中;
三、总结
开发板的技术说明书很重要,有时候在实际操作过程中遇到的问题,可以从技术手册中找到。