STM32利用串口外设发送数据

今天2024.3.21日上午学习了一下基本的串口初始化,利用串口发送一个字节的数据,看时间也快11点了,上午就学习这么多吧,把上午的知识总结一下,串口初始化的过程:

看着图来编写串口初始化的过程:

//第一步:把USART和GPIO的时钟打开

//第二步:GPIO初始化TX复用输出RX输入

//第三步:初始化USART(9600波特率、8位字长、无校验、1位停止位、无流控,只有发送模式)

//第四步:发送开启USART,接收需要配置中断和NVIC

接着来学习一下串口标准库中的函数吧:

下面就是工程中的Serial.c的文件:

cs 复制代码
#include "stm32f10x.h"                  // Device header


void Serial_Init(void)
{
	//第一步:把USART和GPIO的时钟打开
	RCC_APB2PeriphClockCmd(RCC_APB2Periph_USART1, ENABLE);
	RCC_APB2PeriphClockCmd(RCC_APB2Periph_GPIOA, ENABLE);
	
	//第二步:GPIO初始化TX复用输出RX输入
	GPIO_InitTypeDef GPIO_InitStruct;
	GPIO_InitStruct.GPIO_Mode = GPIO_Mode_AF_PP;  //复用推挽输出模式
	GPIO_InitStruct.GPIO_Pin = GPIO_Pin_9;        //因为只写发送,所以只初始化TX引脚就好了
	GPIO_InitStruct.GPIO_Speed = GPIO_Speed_50MHz;  //速率50M
	GPIO_Init(GPIOA, &GPIO_InitStruct);
	
	//第三步:初始化USART(9600波特率、8位字长、无校验、1位停止位、无流控,只有发送模式)
	USART_InitTypeDef USART_InitStruct;
	USART_InitStruct.USART_BaudRate = 9600;            //波特率
	USART_InitStruct.USART_HardwareFlowControl = USART_HardwareFlowControl_None;     //硬件流控  不使用
	USART_InitStruct.USART_Mode = USART_Mode_Tx;     //串口模式   发送模式
	USART_InitStruct.USART_Parity = USART_Parity_No;  //串口校验位   无校验
	USART_InitStruct.USART_StopBits = USART_StopBits_1;   //串口停止位   1位
	USART_InitStruct.USART_WordLength = USART_WordLength_8b;   //串口字长   8位
	USART_Init(USART1, &USART_InitStruct);
	
	//第四部:发送开启USART,接收需要配置中断和NVIC
	USART_Cmd(USART1, ENABLE);
}


// 串口发送一个字节的数据
void Serail_SendByte(uint8_t Byte)
{
	USART_SendData(USART1, Byte);                                 //发送传进来的一个字节的数据
	while(USART_GetFlagStatus(USART1, USART_FLAG_TXE) == RESET);  //等待传送寄存器为空。确认发送完成再结束。
	/*下次写入数据寄存器会自动清除发送完成标志位,故此循环后,无需清除标志位*/
}

下面是Serial.h的文件:

cs 复制代码
#ifndef __SERIAL_H
#define __SERIAL_H

void Serial_Init(void);
// 串口发送一个字节的数据
void Serail_SendByte(uint8_t Byte);

#endif

最后就是主函数main.c的文件了:

cs 复制代码
#include "stm32f10x.h"                  // Device header
#include "OLED.h"
#include "Serial.h"
#include "Delay.h"

uint8_t a=0x01;

int main(void)
{
	OLED_Init();       //oled  屏幕初始化
	Serial_Init();   //串口初始化
	
	
	
	while(1)
	{
		a++;
		Serail_SendByte(a);  //串口发送一个字节的0x42
		OLED_ShowHexNum(1,3,a,2);
		Delay_s(1);
	}
}

这样编译后下载到单片机中就能每隔1秒钟发送一个从1到255的十六进制数字了,发送完并在OLED上显示当前的数字,来看看最后电脑收到的串口数据吧:

由于是文本模式接收的数据所以有些是看不懂的字符,估计是阿斯克码中没有这个字符吧,下面是用十六进制的格式接收数据,来看看效果吧:

相关推荐
CODECOLLECT1 小时前
京元 I62D Windows PDA 技术拆解:Windows 10 IoT 兼容 + 硬解码模块,如何降低工业软件迁移成本?
stm32·单片机·嵌入式硬件
BackCatK Chen1 小时前
STM32+FreeRTOS:嵌入式开发的黄金搭档,未来十年就靠它了!
stm32·单片机·嵌入式硬件·freertos·低功耗·rtdbs·工业控制
全栈游侠4 小时前
STM32F103XX 02-电源与备份寄存器
stm32·单片机·嵌入式硬件
Lsir10110_4 小时前
【Linux】中断 —— 操作系统的运行基石
linux·运维·嵌入式硬件
深圳市九鼎创展科技6 小时前
瑞芯微 RK3399 开发板 X3399 评测:高性能 ARM 平台的多面手
linux·arm开发·人工智能·单片机·嵌入式硬件·边缘计算
辰哥单片机设计6 小时前
STM32项目分享:车辆防盗报警系统
stm32·单片机·嵌入式硬件
風清掦8 小时前
【江科大STM32学习笔记-05】EXTI外部中断11
笔记·stm32·学习
小龙报8 小时前
【51单片机】从 0 到 1 玩转 51 蜂鸣器:分清有源无源,轻松驱动它奏响新年旋律
c语言·数据结构·c++·stm32·单片机·嵌入式硬件·51单片机
范纹杉想快点毕业8 小时前
嵌入式与单片机开发核心学习指南——从思维转变到第一性原理的深度实践
单片机·嵌入式硬件
Industio_触觉智能8 小时前
瑞芯微RK3566开发板规格书,详细参数配置,型号EVB3566-V1,基于RK3566核心板SOM3566邮票孔封装
嵌入式硬件·开发板·rk3568·rk3566·核心板·瑞芯微