STM32 串口收发数据包

接线图

HEX数据包接收

文本数据包接收

代码配置

发送HEX数据包

cs 复制代码
//存储发送或接收的载荷数据
uint8_t TX_Packet[4];
uint8_t RX_Packet[4];

void Serial_SendPacket(void)
{
	Serial_SendByte(0xFF);//发送包头
	Serial_SendArray(TX_Packet, 4);//发送4个载荷数据
	Serial_SendByte(0xFE);//发送包尾
	
	
}

主函数

cs 复制代码
#include "USART.h"
int main(void)
{
	OLED_Init();
	USART_Config();
	TX_Packet[0] = 0x01;
	TX_Packet[1] = 0x02;
	TX_Packet[2] = 0x03;
	TX_Packet[3] = 0x04;
	Serial_SendPacket();
	while(1)
	{
		
		
	}
	
	
}

接收HEX数据包

需要在中断函数里写

cs 复制代码
//存储发送或接收的载荷数据
uint8_t TX_Packet[4];
uint8_t RX_Packet[4];

//中断函数
void USART1_IRQHandler(void)
{
	static uint8_t RX_State = 0;
	static uint8_t pRX_Packet = 0;
	//判断中断标志位
	if(USART_GetITStatus(USART1, USART_IT_RXNE) == SET)
	{
		RX_Data = USART_ReceiveData(USART1);//读取数据寄存器,并存放在数据变量里
		if(RX_State == 0)
		{
			//如果接收到了包头
			if(RX_Data == 0xFF)
			{
				RX_State = 1;
				pRX_Packet = 0;
			}
		}
		else if(RX_State == 1)
		{
			RX_Packet[pRX_Packet] = RX_Data;//将RX_Data存在接收数组里
			pRX_Packet++;
			if(pRX_Packet >= 4)
			{
				RX_State = 2;
			}
		}
		else if(RX_State == 2)
		{
			//判断是不是包尾
			if(RX_Data == 0xFE)
			{
				RX_State = 0;
				RX_Flag = 1;//标志位置1
			}
		}
		
		//清除标志位
		USART_ClearITPendingBit(USART1, USART_IT_RXNE);
	}
	
}

主函数

cs 复制代码
#include "USART.h"
int main(void)
{
	OLED_Init();
	USART_Config();
	TX_Packet[0] = 0x01;
	TX_Packet[1] = 0x02;
	TX_Packet[2] = 0x03;
	TX_Packet[3] = 0x04;
	Serial_SendPacket();
	while(1)
	{
		if(Serial_GetRXFlag() == 1)
		{
			OLED_ShowHexNum(1, 1, RX_Packet[0], 2);
			OLED_ShowHexNum(1, 4, RX_Packet[1], 2);
			OLED_ShowHexNum(1, 7, RX_Packet[2], 2);
			OLED_ShowHexNum(1, 10,RX_Packet[3], 2);
		}
		
	}
	
	
}

按键控制

cs 复制代码
int main(void)
{
	KEY_Init();
	OLED_Init();
	USART_Config();
	TX_Packet[0] = 0x01;
	TX_Packet[1] = 0x02;
	TX_Packet[2] = 0x03;
	TX_Packet[3] = 0x04;
	OLED_ShowString(1, 1, "TXPacket");
	OLED_ShowString(3, 1, "RXPacket");
	while(1)
	{
		if(KEY_Scanf(GPIOB, GPIO_Pin_0) == 1)
		{
				TX_Packet[0]++;
				TX_Packet[1]++;
				TX_Packet[2]++;
				TX_Packet[3]++;
				Serial_SendPacket();
			OLED_ShowHexNum(2, 1, TX_Packet[0], 2);
			OLED_ShowHexNum(2, 4, TX_Packet[1], 2);
			OLED_ShowHexNum(2, 7, TX_Packet[2], 2);
			OLED_ShowHexNum(2, 10,TX_Packet[3], 2);
		}
		if(Serial_GetRXFlag() == 1)
		{
			OLED_ShowHexNum(4, 1, RX_Packet[0], 2);
			OLED_ShowHexNum(4, 4, RX_Packet[1], 2);
			OLED_ShowHexNum(4, 7, RX_Packet[2], 2);
			OLED_ShowHexNum(4, 10,RX_Packet[3], 2);
		}
		
	}

发送与接收文本数据包

cs 复制代码
char RX_Packet2[100];

//中断函数
void USART1_IRQHandler(void)
{
	static uint8_t RX_State = 0;
	static uint8_t pRX_Packet = 0;
	//判断中断标志位
	if(USART_GetITStatus(USART1, USART_IT_RXNE) == SET)
	{
		RX_Data = USART_ReceiveData(USART1);//读取数据寄存器,并存放在数据变量里
		if(RX_State == 0)
		{
			//如果接收到了包头
			if(RX_Data == '@' && RX_Flag == 0)
			{
				RX_State = 1;
				pRX_Packet = 0;
			}
		}
		else if(RX_State == 1)
		{
			//判断是不是第一个包尾
			if(RX_Data == '\r')
			{
				RX_State = 2;
			}
			else
			{
				RX_Packet2[pRX_Packet] = RX_Data;//将RX_Data存在接收数组里
				pRX_Packet++;
			}
		}
		else if(RX_State == 2)
		{
			//判断是不是第二个包尾
			if(RX_Data == '\n')
			{
				RX_State = 0;
				RX_Packet2[pRX_Packet] = '\0';//加结束标志位
				RX_Flag = 1;//标志位置1
			}
		}
		
		//清除标志位
		USART_ClearITPendingBit(USART1, USART_IT_RXNE);
	}
	
}

主函数:

cs 复制代码
int main(void)
{
	
	OLED_Init();
	LED_Init();
	USART_Config();
	OLED_ShowString(1, 1, "TXPacket");
	OLED_ShowString(3, 1, "RXPacket");
	while(1)
	{
		if(RX_Flag == 1)
		{
			OLED_ShowString(4, 1, "            ");
			OLED_ShowString(4, 1, RX_Packet2);
			
			if(strcmp(RX_Packet2, "LED_ON") == 0)
			{
				LED2(0);
				Serial_SendString("LED_ON_OK\r\n");
				OLED_ShowString(2, 1, "           ");
				OLED_ShowString(2, 1, "LED_ON_OK");
			}
			else if(strcmp(RX_Packet2, "LED_OFF") == 0)
			{
				LED2(1);
				Serial_SendString("LED_OFF_OK\r\n");
				OLED_ShowString(2, 1, "            ");
				OLED_ShowString(2, 1, "LED_OFF_OK");
			}
			else
			{
				Serial_SendString("ERROR_COMMAND\r\n");
				OLED_ShowString(2, 1, "              ");
				OLED_ShowString(2, 1, "ERROR_COMMAND");
			}
			RX_Flag = 0;
		}
		
	}
	
	
}
相关推荐
邹诗钰-电子信息工程2 分钟前
bmp280的压力数据采集(i2c设备驱动+设备树编写)
stm32·单片机·嵌入式硬件
guts°2 小时前
17-VRRP
网络·智能路由器
Jewel Q2 小时前
动态路由协议基础
网络·智能路由器
宇称不守恒4.03 小时前
2025暑期—06神经网络-常见网络2
网络·人工智能·神经网络
Dreams_l3 小时前
网络编程2(应用层协议,传输层协议)
运维·服务器·网络
数据与人工智能律师3 小时前
数字迷雾中的安全锚点:解码匿名化与假名化的法律边界与商业价值
大数据·网络·人工智能·云计算·区块链
先知后行。3 小时前
网络协议HTTP、TCP(草稿)
网络·网络协议
xzkyd outpaper4 小时前
QUIC协议如何在UDP基础上解决网络切换问题
网络·计算机网络·udp·quic
Ronin-Lotus4 小时前
嵌入式硬件篇---有线串口通信问题解决
单片机·嵌入式硬件·ttl·rs232·rs485·有线串口
碳酸的唐4 小时前
Inception网络架构:深度学习视觉模型的里程碑
网络·深度学习·架构