当前位置: 首页 > news >正文

STM32f103 标准库 零基础学习之按键点灯(不涉及中断)

 注意,此次代码不涉及中断,不涉及中断,不涉及中断

目录

1.初始化LED

2.初始化按键

3.粗略的延时函数

4.判断引脚电平

5.通过异或反转电平 


开始
│
├── 初始化LED(GPIOA Pin1 推挽输出)
├── 初始化按键(GPIOA Pin0 浮空输入)
│
└── 进入无限循环:│├── 检测按键是否被按下(KEY_Scan1)│       ↓│      是│       ↓└── 翻转LED状态(LED_TOGGLE1)

 1.初始化LED

这个就不赘述了,不会的可以看https://blog.csdn.net/a15884871479/article/details/147851781?spm=1001.2014.3001.5501

我们只保留初始化灯的就可以了。

2.初始化按键

初始化按键的代码和初始化LED灯的代码是相类似的

void KEY_Config(void){// 定义一个 GPIO 结构体 GPIO_InitTypeDef gpio_initstruct = {0};RCC_APB2PeriphClockCmd(RCC_APB2Periph_GPIOA,ENABLE);   //IO输出状态初始化控制//选择要控制的GPIO引脚、设置GPIO模式为 浮空输入、设置GPIO速率为50MHzgpio_initstruct.GPIO_Pin    =  GPIO_Pin_0;gpio_initstruct.GPIO_Mode = GPIO_Mode_IN_FLOATING;gpio_initstruct.GPIO_Speed  = GPIO_Speed_50MHz;GPIO_Init(GPIOA,&gpio_initstruct);
}

解释:我这里的电路图是配置的上拉输入,具体按键要具体配置。

3.粗略的延时函数

void Rough_Delay_Ms1(__IO uint32_t time) {for (uint32_t i = 0; i < 7 * time; i++) {__NOP();}
}
  • 实现一个粗略的毫秒级延时函数。
  • 延时时间由参数time决定,乘以7是为了估算大约1ms的延迟(具体取决于系统主频)。
  • 使用__NOP()指令进行空操作,占用CPU时间达到延时效果。

4.判断引脚电平

int KEY_Scan1(GPIO_TypeDef* GPIOx, uint16_t GPIO_Pin, uint8_t key_press_level)
{if (GPIO_ReadInputDataBit(GPIOx, GPIO_Pin) == key_press_level){Rough_Delay_Ms1(20);  // 消抖延时while (GPIO_ReadInputDataBit(GPIOx, GPIO_Pin) == key_press_level);Rough_Delay_Ms1(20);  // 释放消抖return 1;} else {return 0;}
}
  • 判断指定的按键是否被按下(通过检测电平变化)。
  • 包含两次延时(20ms)用于消除按键抖动:
    • 第一次延时后再次检查按键状态,确保按键确实被按下。
    • 第二次延时用于按键释放后的稳定。

解释:

PIO_ReadInputDataBit(GPIOx, GPIO_Pin)
作用:读取指定 GPIO 引脚的当前输入值。
返回值:
Bit_SET(即 1)表示该引脚为高电平;
Bit_RESET(即 0)表示该引脚为低电平。

5.通过异或反转电平 

void LED_TOGGLE1(GPIO_TypeDef* GPIOx, uint16_t GPIO_Pin) {GPIOx->ODR ^= GPIO_Pin;
}

 然后就把他们组合起来就可以了

#include  "stm32f10x.h"void Rough_Delay_Ms1(__IO uint32_t time){for(uint32_t i = 0;i<7*time;i++){__NOP();}}
void LED_Config(void){GPIO_InitTypeDef gpio_initstruct = {0};//初始化gpio结构体//开启端口时钟RCC_APB2PeriphClockCmd(RCC_APB2Periph_GPIOA,ENABLE); //开启端口时钟//关闭灯GPIO_SetBits(GPIOA,GPIO_Pin_1);//让端口引脚输出1,使得灯灭//配置io模式 推挽模式,50mgpio_initstruct.GPIO_Pin    = GPIO_Pin_1;gpio_initstruct.GPIO_Mode   = GPIO_Mode_Out_PP;gpio_initstruct.GPIO_Speed  = GPIO_Speed_50MHz;GPIO_Init(GPIOA,&gpio_initstruct);//配置端口引脚的模式
}
void KEY_Config(void){// 定义一个 GPIO 结构体 GPIO_InitTypeDef gpio_initstruct = {0};RCC_APB2PeriphClockCmd(RCC_APB2Periph_GPIOA,ENABLE);   //IO输出状态初始化控制//选择要控制的GPIO引脚、设置GPIO模式为 浮空输入、设置GPIO速率为50MHzgpio_initstruct.GPIO_Pin    =  GPIO_Pin_0;gpio_initstruct.GPIO_Mode = GPIO_Mode_IN_FLOATING;gpio_initstruct.GPIO_Speed  = GPIO_Speed_50MHz;GPIO_Init(GPIOA,&gpio_initstruct);
}
int KEY_Scan1(GPIO_TypeDef* GPIOx, uint16_t GPIO_Pin, uint8_t key_press_level)
{if (GPIO_ReadInputDataBit(GPIOx, GPIO_Pin) == key_press_level){Rough_Delay_Ms1(20);  // 消抖延时// 再次确认按键是否仍然处于按下状态while (GPIO_ReadInputDataBit(GPIOx, GPIO_Pin) == key_press_level);Rough_Delay_Ms1(20);  // 释放消抖return 1;}else{return 0;}
}
void LED_TOGGLE1(GPIO_TypeDef* GPIOx, uint16_t GPIO_Pin)
{GPIOx->ODR ^= GPIO_Pin;
}int main(void)
{LED_Config();KEY_Config();while(1){if (KEY_Scan1(GPIOA, GPIO_Pin_0, 1) == 1){LED_TOGGLE1(GPIOA, GPIO_Pin_1);}}
}

相关文章:

  • 二叉搜索树讲解
  • Funplus 服务端开发实习 面经
  • robomaster机甲大师--电调电机
  • Transformer Decoder-Only 算力FLOPs估计
  • 仿真生成激光干涉包裹相位数据-用于深度学习训练!
  • 【信息系统项目管理师】第3章:信息系统治理 - 29个经典题目及详解
  • RHCSA Linux系统 Web页面 论坛 网盘的搭建
  • 架构思维:通用架构模式_怀疑下游的设计思路与最佳实践
  • 基于 TSBS 标准数据集下 TimescaleDB、InfluxDB 与 TDengine 性能对比测试报告
  • 花朵识别系统Python+深度学习+卷积神经网络算法+TensorFlow+人工智能
  • MySQL的索引分类
  • CSS 基础知识分享:从入门到注意事项
  • 基础框架搭建流程指南
  • 如何获取达梦数据库的官方文档?
  • 温湿度传感器SHT4X
  • SpringBoot 自动装配原理 自定义一个 starter
  • 【并发编程】Redisson 的分布式锁
  • 设计模式系列(1):总览与引导
  • 使用PHP对接印度股票市场API
  • 沐言智语开源Muyan-TTS模型,词错率、语音质量评分都处于开源模型的一线水平,推理速度相当快~
  • 自家电脑做网站服务器w7花生壳/想学管理方面的培训班
  • 中国专门做统计网站/企业网站模板
  • 成都网站编辑/襄阳网站seo
  • 督查营商环境建设网站/百度点击软件还有用吗
  • 农药放行单在哪个网站做/厦门seo外包平台
  • 南宁公司建站模板/什么是淘宝seo