STM32F103C8T6使用ESP8266进行无线通信的示例代码
#include "stm32f10x.h"
// 定义串口1的GPIO引脚
#define USART_GPIO GPIOA
#define USART_TX_PIN GPIO_Pin_9
#define USART_RX_PIN GPIO_Pin_10
// 定义ESP8266的连接状态引脚
#define ESP8266_STATUS_GPIO GPIOA
#define ESP8266_STATUS_PIN GPIO_Pin_8
// 定义发送和接收缓冲区大小
#define BUFFER_SIZE 128
// 接收缓冲区
char rx_buffer[BUFFER_SIZE];
// 发送缓冲区
char tx_buffer[BUFFER_SIZE];
// 接收完成标志
volatile uint8_t rx_complete = 0;
// 串口1接收中断处理函数
void USART1_IRQHandler(void)
{
if (USART_GetITStatus(USART1, USART_IT_RXNE) != RESET)
{
static uint8_t rx_index = 0;
char data = USART_ReceiveData(USART1);
rx_buffer[rx_index++] = data;
if (data == '\n' || rx_index >= BUFFER_SIZE - 1)
{
rx_buffer[rx_index] = '\0';
rx_index = 0;
rx_complete = 1;
}
}
}
// 发送字符串到ESP8266模块
void sendToESP8266(const char* str)
{
while (*str)
{
USART_SendData(USART1, *str++);
while (USART_GetFlagStatus(USART1, USART_FLAG_TC) == RESET);
}
}
int main(void)
{
// 初始化USART1
USART_InitTypeDef USART_InitStruct;
GPIO_InitTypeDef GPIO_InitStruct;
RCC_APB2PeriphClockCmd(RCC_APB2Periph_USART1 | RCC_APB2Periph_GPIOA, ENABLE);
// 配置USART1的引脚
GPIO_InitStruct.GPIO_Pin = USART_TX_PIN;
GPIO_InitStruct.GPIO_Mode = GPIO_Mode_AF_PP;
GPIO_InitStruct.GPIO_Speed = GPIO_Speed_50MHz;
GPIO_Init(USART_GPIO, &GPIO_InitStruct);
GPIO_InitStruct.GPIO_Pin = USART_RX_PIN;
GPIO_InitStruct.GPIO_Mode = GPIO_Mode_IN_FLOATING;
GPIO_Init(USART_GPIO, &GPIO_InitStruct);
// 配置USART1的参数
USART_InitStruct.USART_BaudRate = 115200;
USART_InitStruct.USART_WordLength = USART_WordLength_8b;
USART_InitStruct.USART_StopBits = USART_StopBits_1;
USART_InitStruct.USART_Parity = USART_Parity_No;
USART_InitStruct.USART_HardwareFlowControl = USART_HardwareFlowControl_None;
USART_InitStruct.USART_Mode = USART_Mode_Rx | USART_Mode_Tx;
USART_Init(USART1, &USART_InitStruct);
// 使能USART1接收中断
USART_ITConfig(USART1, USART_IT_RXNE, ENABLE);
NVIC_EnableIRQ(USART1_IRQn);
// 初始化ESP8266状态引脚
GPIO_InitStruct.GPIO_Pin = ESP8266_STATUS_PIN;
GPIO_InitStruct.GPIO_Mode = GPIO_Mode_IN_FLOATING;
GPIO_InitStruct.GPIO_Speed = GPIO_Speed_50MHz;
GPIO_Init(ESP8266_STATUS_GPIO, &GPIO_InitStruct);
// 启动USART1
USART_Cmd(USART1, ENABLE);
while (1)
{
// 检查ESP8266连接
if (GPIO_ReadInputDataBit(ESP8266_STATUS_GPIO, ESP8266_STATUS_PIN) == Bit_SET)
{
// ESP8266已连接
// 发送数据到ESP8266模块
if (rx_complete)
{
// 处理接收到的数据
// ...
// 发送数据到ESP8266
sendToESP8266(tx_buffer);
// 清空发送缓冲区
memset(tx_buffer, 0, sizeof(tx_buffer));
// 重置接收完成标志
rx_complete = 0;
}
}
else
{
// ESP8266未连接
// 可以执行重新连接或其他处理
}
}
}
————————————————
版权声明:本文为博主原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。
原文链接:https://blog.csdn.net/m0_56694518/article/details/131482811
#include "stm32f10x.h"
// 定义串口1的GPIO引脚
#define USART_GPIO GPIOA
#define USART_TX_PIN GPIO_Pin_9
#define USART_RX_PIN GPIO_Pin_10
// 定义ESP8266的连接状态引脚
#define ESP8266_STATUS_GPIO GPIOA
#define ESP8266_STATUS_PIN GPIO_Pin_8
// 定义发送和接收缓冲区大小
#define BUFFER_SIZE 128
// 接收缓冲区
char rx_buffer[BUFFER_SIZE];
// 发送缓冲区
char tx_buffer[BUFFER_SIZE];
// 接收完成标志
volatile uint8_t rx_complete = 0;
// 串口1接收中断处理函数
void USART1_IRQHandler(void)
{
if (USART_GetITStatus(USART1, USART_IT_RXNE) != RESET)
{
static uint8_t rx_index = 0;
char data = USART_ReceiveData(USART1);
rx_buffer[rx_index++] = data;
if (data == '\n' || rx_index >= BUFFER_SIZE - 1)
{
rx_buffer[rx_index] = '\0';
rx_index = 0;
rx_complete = 1;
}
}
}
// 发送字符串到ESP8266模块
void sendToESP8266(const char* str)
{
while (*str)
{
USART_SendData(USART1, *str++);
while (USART_GetFlagStatus(USART1, USART_FLAG_TC) == RESET);
}
}
int main(void)
{
// 初始化USART1
USART_InitTypeDef USART_InitStruct;
GPIO_InitTypeDef GPIO_InitStruct;
RCC_APB2PeriphClockCmd(RCC_APB2Periph_USART1 | RCC_APB2Periph_GPIOA, ENABLE);
// 配置USART1的引脚
GPIO_InitStruct.GPIO_Pin = USART_TX_PIN;
GPIO_InitStruct.GPIO_Mode = GPIO_Mode_AF_PP;
GPIO_InitStruct.GPIO_Speed = GPIO_Speed_50MHz;
GPIO_Init(USART_GPIO, &GPIO_InitStruct);
GPIO_InitStruct.GPIO_Pin = USART_RX_PIN;
GPIO_InitStruct.GPIO_Mode = GPIO_Mode_IN_FLOATING;
GPIO_Init(USART_GPIO, &GPIO_InitStruct);
// 配置USART1的参数
USART_InitStruct.USART_BaudRate = 115200;
USART_InitStruct.USART_WordLength = USART_WordLength_8b;
USART_InitStruct.USART_StopBits = USART_StopBits_1;
USART_InitStruct.USART_Parity = USART_Parity_No;
USART_InitStruct.USART_HardwareFlowControl = USART_HardwareFlowControl_None;
USART_InitStruct.USART_Mode = USART_Mode_Rx | USART_Mode_Tx;
USART_Init(USART1, &USART_InitStruct);
// 使能USART1接收中断
USART_ITConfig(USART1, USART_IT_RXNE, ENABLE);
NVIC_EnableIRQ(USART1_IRQn);
// 初始化ESP8266状态引脚
GPIO_InitStruct.GPIO_Pin = ESP8266_STATUS_PIN;
GPIO_InitStruct.GPIO_Mode = GPIO_Mode_IN_FLOATING;
GPIO_InitStruct.GPIO_Speed = GPIO_Speed_50MHz;
GPIO_Init(ESP8266_STATUS_GPIO, &GPIO_InitStruct);
// 启动USART1
USART_Cmd(USART1, ENABLE);
while (1)
{
// 检查ESP8266连接
if (GPIO_ReadInputDataBit(ESP8266_STATUS_GPIO, ESP8266_STATUS_PIN) == Bit_SET)
{
// ESP8266已连接
// 发送数据到ESP8266模块
if (rx_complete)
{
// 处理接收到的数据
// ...
// 发送数据到ESP8266
sendToESP8266(tx_buffer);
// 清空发送缓冲区
memset(tx_buffer, 0, sizeof(tx_buffer));
// 重置接收完成标志
rx_complete = 0;
}
}
else
{
// ESP8266未连接
// 可以执行重新连接或其他处理
}
}
}
————————————————
版权声明:本文为博主原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。
原文链接:https://blog.csdn.net/m0_56694518/article/details/131482811