今天2024.3.21日上午学习了一下基本的串口初始化,利用串口发送一个字节的数据,看时间也快11点了,上午就学习这么多吧,把上午的知识总结一下,串口初始化的过程:
看着图来编写串口初始化的过程:
//第一步:把USART和GPIO的时钟打开
//第二步:GPIO初始化TX复用输出RX输入
//第三步:初始化USART(9600波特率、8位字长、无校验、1位停止位、无流控,只有发送模式)
//第四步:发送开启USART,接收需要配置中断和NVIC
接着来学习一下串口标准库中的函数吧:
下面就是工程中的Serial.c的文件:
#include "stm32f10x.h" // Device headervoid 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; //速率50MGPIO_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,接收需要配置中断和NVICUSART_Cmd(USART1, ENABLE);
}// 串口发送一个字节的数据
void Serail_SendByte(uint8_t Byte)
{USART_SendData(USART1, Byte); //发送传进来的一个字节的数据while(USART_GetFlagStatus(USART1, USART_FLAG_TXE) == RESET); //等待传送寄存器为空。确认发送完成再结束。/*下次写入数据寄存器会自动清除发送完成标志位,故此循环后,无需清除标志位*/
}
下面是Serial.h的文件:
#ifndef __SERIAL_H
#define __SERIAL_Hvoid Serial_Init(void);
// 串口发送一个字节的数据
void Serail_SendByte(uint8_t Byte);#endif
最后就是主函数main.c的文件了:
#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); //串口发送一个字节的0x42OLED_ShowHexNum(1,3,a,2);Delay_s(1);}
}
这样编译后下载到单片机中就能每隔1秒钟发送一个从1到255的十六进制数字了,发送完并在OLED上显示当前的数字,来看看最后电脑收到的串口数据吧:
由于是文本模式接收的数据所以有些是看不懂的字符,估计是阿斯克码中没有这个字符吧,下面是用十六进制的格式接收数据,来看看效果吧: