STM32用软件实现上升沿检测的方法

基本思路

  1. 定义一个静态变量Rtrig初始化为0;
  2. 当按键按下时先适当延时进行滤波处理,再次判断按键的有效性;
  3. 如果按键有效则判断Rtrig的值,如果Rtrig的值为0,则将Rtrig赋值为1,否则将Rtrig赋值为2
  4. 如果按键无效则将Rtrig赋值为0;
  5. 最后返回(Rtrig== 1)

代码实现 

#define UNTRIGED    0 //未触发状态
#define TRIGED      1 //已触发状态
#define OTHER_STATE 2 //其他状态
#define u32 unsigned int
#define ON  1 //Pin为高电平
#define OFF 0 //Pin为低电平
void CheckRtrig(u32 PinValue){
    //定义静态变量Rtrig取值范围(UNTRIGED:0; TRIGED:1;OTHER_STATE 2)来状态存储
    //当前状态,并将其初始化为未触发状态(UNTRIGED)
    static u32 Rtrig = UNTRIGED;
    //检测Pin状态是否有效
    if(PinValue == ON){
        //延时滤波
        Delay_ms(100);
        //再次检测Pin状态是否有效
        if(PinValue == ON){
            //如果当前状态为,未触发状态(UNTRIGED),则将其变更为触发状态(TRIGED)
            if(Rtrig == UNTRIGED ){
                Rtrig = TRIGED;
            }else{
            //如果当前状态为触发状态(UNTRIGED)或其他状态(OTHER_STATE),将当前状态
            //变更为其他状态
                Rtrig = OTHER_STATE;
            }
        }
    }else{//如果按键无效则将状态变更为未触发状态(UNTRIGED)
        Rtrig = UNTRIGED;
    }
    return (Rtrig == TRIGED)
}
void Delay_ms(u32 i){
    u32 temp;
    //设置重装数值, 72MHZ时
    SysTick->LOAD = 9000 * i; 
    //使能,减到零是无动作,采用外部时钟源     
    SysTick->CTRL=0X01;
    //清零计数器        
    SysTick->VAL=0;            
    do{
        //读取当前倒计数值
        temp=SysTick->CTRL;       
    }while((temp & 0x01) && (!(temp & (1 << 16))));    //等待时间到达
    //关闭计数器
    SysTick->CTRL=0;  
    //清空计数器                        
    SysTick->VAL=0;                           
}

 

### STM32 按键上升沿和下降沿检测的代码实现及原理分析 #### 一、硬件连接与初始化配置 为了实现按键的上升沿和下降沿检测,首先需要了解STM32如何通过外部中断线(EXTI)来响应GPIO引脚上的电平变化。STM32支持多达20条外部中断/事件线[^2],这意味着可以针对多个不同的IO口设置独立的边沿触发条件。 对于每一个用于按键输入的GPIO端口位,在初始化阶段应该将其配置成浮空输入模式或者上拉/下拉电阻输入模式,并开启相应的外部中断通道。具体来说: - **选择合适的GPIO引脚作为按键接口** - **使能对应的AFIO时钟以及RCC外设时钟** - **设定该引脚为输入状态** ```c // 初始化 GPIO 和 EXTI 中断 void Key_GPIO_EXTI_Init(void){ GPIO_InitTypeDef GPIO_InitStruct; __HAL_RCC_GPIOA_CLK_ENABLE(); // 开启 PA 端口时钟 /* 配置PA0为输入 */ GPIO_InitStruct.Pin = GPIO_PIN_0; GPIO_InitStruct.Mode = GPIO_MODE_IT_FALLING; // 设置为下降沿触发 HAL_GPIO_Init(GPIOA, &GPIO_InitStruct); } ``` #### 二、软件处理逻辑设计 当发生指定类型的跳变(即上升沿或下降沿)时,会自动进入相应的中断服务程序(ISR),在此处编写具体的业务逻辑即可完成对按键动作的有效识别。 ##### 下降沿检测实例 在接收到下降沿信号后,通常会在ISR里执行如下操作: 1. 清除标志位以防重复触发; 2. 执行特定的任务比如点亮LED或其他控制指令; ```c // 外部中断回调函数 void HAL_GPIO_EXTI_Callback(uint16_t GPIO_Pin){ if (GPIO_Pin == GPIO_PIN_0){ // 当检测到PA0引脚上有下降沿产生时调用此部分代码 // 插入去抖动延时 HAL_Delay(10); // 判断当前按键是否仍然处于低电平 if(HAL_GPIO_ReadPin(GPIOA, GPIO_PIN_0)==RESET){ // 如果确实按下,则进行相应操作 // 如切换RGB LED颜色等... // 更新上次按下的时间戳以便后续防连发等功能扩展 } // 清除中断标志位 __HAL_GPIO_EXTI_CLEAR_FLAG(GPIO_PIN_0); } } ``` ##### 上升沿检测方法 同样地,也可以很容易地修改上述例子中的`Mode`参数值改为`GPIO_MODE_IT_RISING`从而达到监测上升沿的目的。另外一种方式是在同一个ISR内同时监听两种边缘的变化情况,这可以通过组合使用宏定义`GPIO_MODE_IT_RISING_FALLING`来轻松达成目的。 #### 三、抗干扰措施——消抖算法的应用 实际应用中由于机械开关本身的特性可能会带来误触问题,因此有必要加入简单的软硬件滤波机制消除这种影响。常见的做法就是在每次捕捉到有效边沿之前增加一段短暂的时间延迟(`HAL_Delay()`)再做进一步确认,确保真正发生了期望的状态转换而不是瞬态噪声所引起的虚假变动。 ---
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

Tomhex

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值