stm32串口发送+接收

本文章转自B站江科大自化协

一发送

接线图

 目标结构

Serial.c

 

#include "stm32f10x.h"  
#include <stdio.h>//1移植printf函数
//封装sprintf
#include <stdarg.h>

void Serial_Init(void)
{
	   RCC_APB2PeriphClockCmd(RCC_APB2Periph_USART1, ENABLE);//开启USART1的时钟
		RCC_APB2PeriphClockCmd(RCC_APB2Periph_GPIOA, ENABLE);//开启GPIOA的时钟
	//初始化GPIOA的引角
    GPIO_InitTypeDef GPIO_InitStructure;
	GPIO_InitStructure.GPIO_Mode = GPIO_Mode_AF_PP;   //复用推挽输出
    GPIO_InitStructure.GPIO_Pin = GPIO_Pin_1 | GPIO_Pin_9;
	GPIO_InitStructure.GPIO_Speed  = GPIO_Speed_50MHz ;
	GPIO_Init(GPIOA,&GPIO_InitStructure);
	//初始化USART
	USART_InitTypeDef USART_InitStruture;
	//波特率的数值
	USART_InitStruture.USART_BaudRate=9600;
	//硬件流控制
	USART_InitStruture.USART_HardwareFlowControl=USART_HardwareFlowControl_None;//不使用流控
	//串口模式
	USART_InitStruture.USART_Mode=USART_Mode_Tx;//发送模式
	//校验位
	USART_InitStruture.USART_Parity=USART_Parity_No;//不校验
	//停止位
	USART_InitStruture.USART_StopBits=USART_StopBits_1;//1位停止位
	//字长
	USART_InitStruture.USART_WordLength=USART_WordLength_8b;//8位
	USART_Init(USART1,&USART_InitStruture);
	
	USART_Cmd(USART1, ENABLE);
}
//写一个发送数据的函数
void Serial_SendByte(uint8_t Byte)
{
	//
	USART_SendData(USART1, Byte);
	//等待标志位
	while(USART_GetFlagStatus(USART1,USART_FLAG_TXE) == RESET);

}
//写一个发送数组的函数
void Serial_SendArray(uint8_t *Array, uint16_t Length)
{
	uint16_t i;
	for (i=0;i<Length;i++)
	{
			Serial_SendByte(Array[i]);
	}
	
}
//写一个SendString函数
void Serial_SendString(char *String)
{
			uint8_t i;
	        for(i=0; String[i] != '\0'; i++)
	   {
	   Serial_SendByte(String[i]);
	   
	   }
		
}
//写一个次方函数
uint32_t Serial_Pow(uint32_t X,uint32_t Y)
{
	uint32_t Result=1;
	while( Y --)
	{
			Result *=X;
	}
	return Result;
}
//写一个SendNum函数
void Serial_SendNumber(uint32_t Number, uint8_t Length)
{
	uint8_t i;
	for(i = 0; i<Length; i++)
	{
			   Serial_SendByte(Number / Serial_Pow(10, Length - i - 1) %10 + '0');
	}

}
//2移植printf函数
//重写fputc函数
int fputc (int ch, FILE *f)
{
	//把fputc函数重定向到串口
	Serial_SendByte(ch);
	return ch;
}
//封装    sprintf
void Serial_Printf(char *format, ...)
{
		char String[100];
	//定义一个参数列表量
	va_list arg;
	//从format位置开始接收参数表,放到arg里面
	va_start(arg,format);
	vsprintf(String, format, arg);
	//释放参数表
	va_end(arg);
	//把String发送出去
	Serial_SendString(String);
	
}

 Serial.h

#ifndef __SERIAL_H
#define __SERIAL_H
#include <stdio.h>
void Serial_Init(void);
void Serial_SendByte(uint8_t Byte);
void Serial_SendArray(uint8_t *Array,uint16_t Length);
void Serial_SendString(char *String);
void Serial_SendNumber(uint32_t Number, uint8_t Length);
void Serial_Printf(char *format, ...);
#endif

main.c

#include "stm32f10x.h"                  // Device header
#include "Delay.h"
#include "OLED.h"
#include "Serial.h"

int main(void)
{
	 OLED_Init();
     Serial_Init();
    //	 Serial_SendByte('A');   
    //     uint8_t MyArray[] = {0x42,0x43,0x44,0x45};
    //	 Serial_SendArray(MyArray,4);
	 Serial_SendString("\r\nNum1=");
	Serial_SendNumber(123,3);
    printf("\r\nNum2=%d",666);//方法1
	//方法二使用sprintf
	char String[100];
    sprintf(String,"\r\nNum3=%d",888);
	Serial_SendString(String);
//	使用封装好的
	Serial_Printf("\r\nNum4 =%d",44444);
	Serial_Printf("\r\n");
	while (1)
	{
		
	}
}

下载测试

 

 二接收

Serial.c

#include "stm32f10x.h"  
#include <stdio.h>//1移植printf函数
//封装sprintf
#include <stdarg.h>

uint8_t Serial_RxData;
uint8_t Serial_RxFlag;

void Serial_Init(void)
{
	   RCC_APB2PeriphClockCmd(RCC_APB2Periph_USART1, ENABLE);//开启USART1的时钟
		RCC_APB2PeriphClockCmd(RCC_APB2Periph_GPIOA, ENABLE);//开启GPIOA的时钟
	//初始化GPIOA的引角 发送
    GPIO_InitTypeDef GPIO_InitStructure;
	GPIO_InitStructure.GPIO_Mode = GPIO_Mode_AF_PP;   //复用推挽输出
    GPIO_InitStructure.GPIO_Pin = GPIO_Pin_1 | GPIO_Pin_9;
	GPIO_InitStructure.GPIO_Speed  = GPIO_Speed_50MHz ;
	GPIO_Init(GPIOA,&GPIO_InitStructure);
	//接收
	GPIO_InitStructure.GPIO_Mode = GPIO_Mode_IPU;   //上接输入
    GPIO_InitStructure.GPIO_Pin = GPIO_Pin_1 | GPIO_Pin_10;
	GPIO_InitStructure.GPIO_Speed  = GPIO_Speed_50MHz ;
	GPIO_Init(GPIOA,&GPIO_InitStructure);
	//初始化USART
	USART_InitTypeDef USART_InitStruture;
	//波特率的数值
	USART_InitStruture.USART_BaudRate=9600;
	//硬件流控制
	USART_InitStruture.USART_HardwareFlowControl=USART_HardwareFlowControl_None;//不使用流控
	//串口模式
	USART_InitStruture.USART_Mode=USART_Mode_Tx | USART_Mode_Rx;//发送模式或接收模式
	//校验位
	USART_InitStruture.USART_Parity=USART_Parity_No;//不校验
	//停止位
	USART_InitStruture.USART_StopBits=USART_StopBits_1;//1位停止位
	//字长
	USART_InitStruture.USART_WordLength=USART_WordLength_8b;//8位
	USART_Init(USART1,&USART_InitStruture);
	
	
	//开启中断
	USART_ITConfig(USART1,USART_IT_RXNE,ENABLE);//开启RXNE标志位到NVIC的输出
	//配置NVIC
	NVIC_PriorityGroupConfig(NVIC_PriorityGroup_2);
	//初始化NVIC的USART1通道
	NVIC_InitTypeDef NVIC_InitStructure;
	NVIC_InitStructure.NVIC_IRQChannel=USART1_IRQn;//中断通道
	NVIC_InitStructure.NVIC_IRQChannelCmd=ENABLE;
	NVIC_InitStructure.NVIC_IRQChannelPreemptionPriority=1;
	NVIC_InitStructure.NVIC_IRQChannelSubPriority=1;
	NVIC_Init(&NVIC_InitStructure);
	
	
	
	USART_Cmd(USART1, ENABLE);
	
}



//写一个发送数据的函数
void Serial_SendByte(uint8_t Byte)
{
	//
	USART_SendData(USART1, Byte);
	//等待标志位
	while(USART_GetFlagStatus(USART1,USART_FLAG_TXE) == RESET);

}
//写一个发送数组的函数
void Serial_SendArray(uint8_t *Array, uint16_t Length)
{
	uint16_t i;
	for (i=0;i<Length;i++)
	{
			Serial_SendByte(Array[i]);
	}
	
}
//写一个SendString函数
void Serial_SendString(char *String)
{
			uint8_t i;
	        for(i=0; String[i] != '\0'; i++)
	   {
	   Serial_SendByte(String[i]);
	   
	   }
		
}
//写一个次方函数
uint32_t Serial_Pow(uint32_t X,uint32_t Y)
{
	uint32_t Result=1;
	while( Y --)
	{
			Result *=X;
	}
	return Result;
}
//写一个SendNum函数
void Serial_SendNumber(uint32_t Number, uint8_t Length)
{
	uint8_t i;
	for(i = 0; i<Length; i++)
	{
			   Serial_SendByte(Number / Serial_Pow(10, Length - i - 1) %10 + '0');
	}

}
//2移植printf函数
//重写fputc函数
int fputc (int ch, FILE *f)
{
	//把fputc函数重定向到串口
	Serial_SendByte(ch);
	return ch;
}
//封装    sprintf
void Serial_Printf(char *format, ...)
{
		char String[100];
	//定义一个参数列表量
	va_list arg;
	//从format位置开始接收参数表,放到arg里面
	va_start(arg,format);
	vsprintf(String, format, arg);
	//释放参数表
	va_end(arg);
	//把String发送出去
	Serial_SendString(String);
	
}
//接收和变量的封装
uint8_t Serial_GetRxFlag(void)
{

	if(Serial_RxFlag == 1)
	{
	  Serial_RxFlag = 0;
		return 1;
	}
    return 0 ;
}
uint8_t Serial_GetRxData(void)
	
{
	return Serial_RxData;

}
void USART1_IRQHandler(void)
	
{
	if(USART_GetITStatus(USART1, USART_IT_RXNE)== SET)
	{
		Serial_RxData = USART_ReceiveData(USART1);
		Serial_RxFlag = 1;
		USART_ClearITPendingBit(USART1,USART_IT_RXNE);
	
	}
 
}

serial.h

#ifndef __SERIAL_H
#define __SERIAL_H
#include <stdio.h>
void Serial_Init(void);
void Serial_SendByte(uint8_t Byte);
void Serial_SendArray(uint8_t *Array,uint16_t Length);
void Serial_SendString(char *String);
void Serial_SendNumber(uint32_t Number, uint8_t Length);
void Serial_Printf(char *format, ...);

uint8_t Serial_GetRxData(void);
uint8_t Serial_GetRxFlag(void);

#endif

main.c

#include "stm32f10x.h"                  // Device header
#include "Delay.h"
#include "OLED.h"
#include "Serial.h"

uint8_t RxData;

int main(void)
{
	 OLED_Init();
     Serial_Init();
	OLED_ShowString(1,1,"RxData:");
    
	while (1)
	{
		if(Serial_GetRxFlag()==1)
		{
				RxData = Serial_GetRxData();
			    Serial_SendByte(RxData);
			    OLED_ShowHexNum(1,8,RxData,2);
			    
		}
	}
}

下载编译 

 

 

 

 

 

  • 1
    点赞
  • 14
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值