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;
		}
		
	}
	
	
}
相关推荐
7***u21619 小时前
显卡(Graphics Processing Unit,GPU)架构详细解读
大数据·网络·架构
学生哥-_-1 天前
STM32点亮WS2812 RGB灯板展示像素图片(一种较方便的取色值数据的方法)
stm32·单片机·嵌入式硬件
河北瑾航科技1 天前
广西水资源遥测终端 广西水利遥测终端 广西用水监测遥测终端 河北瑾航科技遥测终端机HBJH-B01说明书
网络·科技·水文遥测终端机·遥测终端机·广西水资源遥测终端机·广西水利遥测终端·广西用水终端
西欧伯爵1 天前
模拟电路入门四
单片机·嵌入式硬件·集成电路
偶像你挑的噻1 天前
12-Linux驱动开发- SPI子系统
linux·驱动开发·stm32·嵌入式硬件
羑悻的小杀马特1 天前
轻量跨云·掌控无界:Portainer CE + cpolar 让远程容器运维像点外卖一样简单——免复杂配置,安全直达对应集群
运维·网络·安全·docker·cpolar
逆小舟1 天前
【STM32】手把手教你完成“天气预报项目”
stm32·单片机·嵌入式硬件
愚戏师1 天前
Python3 Socket 网络编程复习笔记
网络·笔记
降临-max1 天前
JavaSE---网络编程
java·开发语言·网络·笔记·学习
赖small强1 天前
【Linux 网络基础】libwebsockets HTTPS 服务端实现机制详解
linux·网络·https·tls·libwebsockets