实验要求:电脑串口控制单片机的LED灯
led.c

#include "led.h"
#include "delay.h"
/*初始化led所在口的时钟以及一些输入输出的相关设置*/void Led_Init()
{GPIO_InitTypeDef GPIO_Initstructure;RCC_AHB1PeriphClockCmd(RCC_AHB1Periph_GPIOF,ENABLE);//使能GPIOF口的时钟GPIO_Initstructure.GPIO_Pin = GPIO_Pin_9|GPIO_Pin_10;//设置输入输出引脚GPIO_Initstructure.GPIO_Mode = GPIO_Mode_OUT;//设置为输出GPIO_Initstructure.GPIO_PuPd  = GPIO_PuPd_UP;//输出上拉GPIO_Initstructure.GPIO_Speed  =GPIO_Fast_Speed;//输出速度为高速GPIO_Initstructure.GPIO_OType  = GPIO_OType_PP;//输出模式为推挽GPIO_Init(GPIOF,&GPIO_Initstructure);//GPIO的初始化GPIO_SetBits(GPIOF,GPIO_Pin_9 | GPIO_Pin_10);//GPIOF9,F10设置高,灯灭}/*****************************************
函数: void Led_flash()
作用: led闪烁
返回值:void
参数:void
作者:马伟
********************************************/
void Led_flash()
{for(int i=0;i<5;i++){GPIO_SetBits(GPIOF,GPIO_Pin_9 | GPIO_Pin_10);//GPIOF9,F10设置高,灯灭delay_ms(300);GPIO_ResetBits(GPIOF,GPIO_Pin_9 | GPIO_Pin_10);//GPIOF9,F10设置低,灯亮delay_ms(300);}}

led.h

#ifndef __LED_H
#define __LED_H
#include "sys.h"
#define LED1 PFout(9)     // D1
#define LED2 PFout(10)  // D2   void Led_Init(void);//led初始化函数void Led_flash(void);//LED闪烁函数#endif

My_usart.c

在#include "My_usart.h"
#include "sys.h"
#include <stdio.h>
//第一步GPIO的复用
void My_usart_init(int boud_rate)
{GPIO_InitTypeDef GPIO_Initstructure;//GPIO初始化结构体USART_InitTypeDef USART_Initstructure;//串口初始化结构体//(1)第一步,使能串口时钟和对应GPIO口的时钟//GPIOA 和 USART1 时钟使能RCC_AHB1PeriphClockCmd(RCC_AHB1Periph_GPIOA,ENABLE); //使能 GPIOA 时钟RCC_APB2PeriphClockCmd(RCC_APB2Periph_USART1,ENABLE );//使能 USART1 // (2)设置引脚复用器映射:调用 GPIO_PinAFConfig 函数。GPIO_PinAFConfig(GPIOA,GPIO_PinSource9,GPIO_AF_USART1);//PA9 复用为 USART1GPIO_PinAFConfig(GPIOA,GPIO_PinSource10,GPIO_AF_USART1);//PA10 复用为 USART1// (3)GPIO 初始化设置:要设置模式为复用功能。GPIO_Initstructure.GPIO_Pin = GPIO_Pin_9|GPIO_Pin_10;//GPIO口A9和A10GPIO_Initstructure.GPIO_Mode = GPIO_Mode_AF;//复用功能GPIO_Initstructure.GPIO_PuPd = GPIO_PuPd_UP;//上拉GPIO_Initstructure.GPIO_Speed = GPIO_Fast_Speed;//速度 50MHzGPIO_Initstructure.GPIO_OType = GPIO_OType_PP;//推挽复用输出GPIO_Init(GPIOA,&GPIO_Initstructure); //初始化 PA9,PA10//(4)USART 初始化设置USART_Initstructure.USART_BaudRate =boud_rate;//波特率USART_Initstructure.USART_WordLength = USART_WordLength_8b;//字长为八位数据格式USART_Initstructure.USART_StopBits =USART_StopBits_1 ;//一个停止位USART_Initstructure.USART_Parity = USART_Parity_No ;//无奇偶校验USART_Initstructure.USART_Mode =USART_Mode_Rx|USART_Mode_Tx ;//接收和发送模式USART_Initstructure.USART_HardwareFlowControl =USART_HardwareFlowControl_None ;//异步不需要硬件流控制USART_Init(USART1,&USART_Initstructure);//初始化串口//配置中断
//NVIC_Configuration();//使能串口
USART_Cmd(USART1, ENABLE);
}
void NVIC_Configuration()
{NVIC_InitTypeDef NVIC_InitStructure;//中断结构体//Usart1 NVIC 配置NVIC_InitStructure.NVIC_IRQChannel = USART1_IRQn;//串口1中断通道NVIC_InitStructure.NVIC_IRQChannelPreemptionPriority=3;//抢占优先级3NVIC_InitStructure.NVIC_IRQChannelSubPriority =3;       //子优先级3NVIC_InitStructure.NVIC_IRQChannelCmd = ENABLE;         //IRQ通道使能NVIC_Init(&NVIC_InitStructure);    //根据指定的参数初始化VIC寄存器、//使能串口接收中断//USART_ITConfig(USART1,USART_IT_RXNE,ENABLE);
/*如果不进入中断函数,就要停止使能中断,否则进入死循环*/    }
//发送单个字符函数
void Usart_SendByte(USART_TypeDef *pUSART,uint8_t ch)
{USART_SendData(USART1,ch);/*这个过程是硬件自动完成的,所以我们只需要等待就可以我们给CPU这个命令之后,传输过程就自动进行了*/while( USART_GetFlagStatus(pUSART,USART_FLAG_TXE)==RESET);//USART_FLAG_TXE为发送寄存器空标志位,USART_FLAG_TC为发送移位寄存器标志位//等于0表示没有发完,就一直等待他发完,为1表示发完//USART_IT_TXE和USART_IT_TC中断标志位
}/*字符串发送函数*/
void Usart_Sendstring(USART_TypeDef *pUSART,char *str)
{unsigned int i=0;/* CPU 将数据帧里的每个字节按顺序转入 发送移位寄存器*/do{Usart_SendByte(pUSART,*(str+i));i++; } while( *(str+i) != '\0' );/* 等待 发送移位寄存器  将数据帧的最后一个字节的最后一位发送出去,整个数据帧发送完毕 ,这个过程是硬件自动完成的,所以我们只需要等待就可以 */while( USART_GetFlagStatus(pUSART,USART_FLAG_TC)==RESET){}}
/*重构c库函数printf到串口*/
int fputc(int ch ,FILE *f)
{USART_SendData(USART1,(unsigned char) ch);while( USART_GetFlagStatus(USART1,USART_FLAG_TXE)==RESET);return (ch);
}///重定向c库函数scanf到串口,重写向后可使用scanf、getchar等函数
int fgetc(FILE *f)
{/* 等待串口输入数据 */while (USART_GetFlagStatus(USART1, USART_FLAG_RXNE) == RESET);return (int)USART_ReceiveData(USART1);}这里插入代码片

特别注意的是printf和getchar函数的重定向

在这里插入int fputc(int ch ,FILE *f)
{USART_SendData(USART1,(unsigned char) ch);while( USART_GetFlagStatus(USART1,USART_FLAG_TXE)==RESET);return (ch);
}///重定向c库函数scanf到串口,重写向后可使用scanf、getchar等函数
int fgetc(FILE *f)
{/* 等待串口输入数据 */while (USART_GetFlagStatus(USART1, USART_FLAG_RXNE) == RESET);return (int)USART_ReceiveData(USART1);}代码片

mian.c

int  main(void)
{delay_init(168);       //延时初始化 My_usart_init(115200);Led_Init();//led初始化函数Led_flash();//LED闪烁函数show();char ch;
while(1)
{ch =getchar();printf("你输入的数字是:%c",ch);switch(ch){case '1':LED1=1;break;case '2':LED2=0;break;case '3':Led_flash();break;default :;break;}
}
return 0;
}static void show()
{printf("1: 灯1亮\n");printf("2:灯2灭\n");printf("3:灯闪\n");
}

stm32串口控制LED灯相关推荐

  1. STM32定时器控制LED灯闪烁及PWM练习

    一.STM32定时器控制LED灯闪烁 1.相关配置 1)配置RCC和SYS 2)配置IO 配置PC15,并命名为D1. 3)配置定时器 选定时器2,配置Clock Source为Internal Cl ...

  2. CC2530串口控制LED灯奇怪玩法

    CC2530串口控制LED灯奇怪玩法 实验目的:CC2530用串口从上位机发送16进制命令代码来控制LED3.4.5.6并返回相应动作 文章目录 CC2530串口控制LED灯奇怪玩法 一.串口设置 二 ...

  3. 单片机:电脑通过串口控制LED灯

    题目概述: 电脑通过串口控制LED灯. 编程: #include<REG52.h> void delay(unsigned int xms) { unsigned int i,j; for ...

  4. 【GD32F427开发板试用】-01-UART1 串口控制LED灯亮灭

    本篇文章来自极术社区与兆易创新组织的GD32F427开发板评测活动,更多开发板试用活动请关注极术社区网站.作者:智能家居-九俊楚子 今天用GD32F427R开发板先测试了UART1的通信功能,然后通过 ...

  5. STM32中断控制LED灯亮灭

    目录 一.中断介绍 1.中断分类 硬件中断(Hardware Interrupt) 软件中断(Software Interrupt) 2.中断优先级 3.中断源种类 4.中断响应原则 二.新建项目 1 ...

  6. STM32按钮控制LED灯的开关

    Hi, I'm Shendi 在之前已经可以控制 PC13 LED灯了,这次加上按钮来控制 首先上效果 STM32按钮控制LED 我使用的是四脚按钮,默认引脚弯折相同的相通,不同不同,按下后四脚都通 ...

  7. STM32中断控制LED灯

    文章目录 一.相关概念 1.中断概念 2.中断过程 3.中断作用 4.中断优先级 5.中断响应过程 二. CubeMX中断控制LED灯 1.创建项目 2.代码修改 3.运行结果 三.HAL库中断串口通 ...

  8. STM32按键控制LED灯亮灭(四)

    编程要点: 1)使能GPIO端口时钟: 2)初始化GPIO目标引脚为输入模式(浮空输入): 3)编写简单测试程序,检测按键的状态,实现按键控制LED灯: bsp_led.h文件 #ifndef T_L ...

  9. STM32中断控制LED灯闪烁

    文章目录 一.中断 1.中断全过程 2.中断优先级 3.HAL库外部中断处理流程 4.中断回调函数 二.实现LED灯 三.实现项目 四.实验结果 五.总结 一.中断 1.中断全过程 中断发生 当CPU ...

  10. STM32按键控制LED灯(中断实现)

    文章目录 1- 轮询模式和中断模式 2- 配置管脚为中断模式 3- 添加代码 4- 具体实现原理 5- main()--第一个执行程序? 在一般情况下,我们希望实现按键控制灯的亮和灭,这次学习的是中断 ...

最新文章

  1. Ruby之Enumerator类
  2. ASP.NET MVC自定义ActionResult实现文件压缩
  3. 125.数据传输方式
  4. 华为emui10是鸿蒙,昨日,华为EMUI10,鸿蒙系统正式发布!
  5. Visual Studio2008安装后更换调试器的问题
  6. SDUT 3379 数据结构实验之查找七:线性之哈希表
  7. 金蝶显示服务器异常,金蝶提示云服务器异常
  8. Git的GUI工具sourcetree的使用
  9. 2021曾都二中高考成绩查询入口,2021高考-随州设4个考区11个考点·
  10. 量化信噪比 非均匀量化_键摄基础1:为什么要正确曝光/ADC精度和量化噪声
  11. RCP中如何使用代码安装、运行plugins
  12. SkeyePlayer RTSP播放器源码解析系列之H264一帧多NAL写MP4录像花屏问题解决方案
  13. Android 头像定位图标
  14. “大数据应用场景”之隔壁老王(连载一)
  15. 前端实战:教你写出简单的侧边栏功能以及返回顶部特效
  16. 国科大数据挖掘课程总结
  17. 17/10/2019 细胞死亡的十一种方式--转自解螺旋公众号
  18. excel不显示0_Excel中把0显示为空白的三种解决方法
  19. Solr安装配置(包含Tomcat和jdk)
  20. 浙江中级聘用计算机还需要吗,浙江省中级高级职称计算机考试要考几个模块?...

热门文章

  1. 海关179对接问题及解决办法大集锦
  2. JAVA Map类compute方法详解及样例
  3. mysql compute_compute by 的使用
  4. mac sz rz file tras
  5. CTC loss 理解
  6. mac上禁用复制粘贴
  7. WiFi路由器的速度到底怎么算的?
  8. 抖音数据统计_抖音账号数据分析
  9. js、Java的url参数转码(url里中文、特殊符号参数转码)
  10. 高中数学知识点总结归纳之立体几何