esp开发与应用(按键和状态机)

【 声明:版权所有,欢迎转载,请勿用于商业用途。 联系信箱:feixiaoxing @163.com】

人机交互的方式很多,有语音、有触摸屏、有按键。不过最经济的方法来说,还是按键。毕竟和其它方式相比,按键还是太便宜了。当然按键也有自己的一个小问题,那就是抖动。只要解决好了这个问题,按键就可以帮助我们解决很多事情。作为一个基础电路,按键的自身其实意义不大,它的存在就是可以帮助我们构建状态机,并且在这个状态机下面衍生出很多的软件功能。

1、按键和屏幕

如果不是特别好的屏幕,简单的spi屏幕价格也不是很贵。但它和按键搭配之后,就可以构建出各种状态,实现各种功能。这些功能可以是消费级的,可以是工业的,也可以是医疗的。

2、按键电路

大部分按键电路都是上拉电路。也就是如上面图片所示,按键没有按下去的时候,vcc透过电阻直连gpio口,这个时候gpio的输入都是1。等到按键按下去的时候,vcc通过电阻就直接泄压到gnd,而gnd直连到gpio,这个时候gpio的输入就是0。这就是按键的基本原理。

有人说,不要电阻行不行。按键没有按下去的时候,可能问题不大。但是一旦按键按下去,就短路了。

3、去抖的原理

去抖的原理其实比较简单,就是按键按下去的时候,别着急修改状态,而是记录当前状态改变时的起始时间。等到这个时间超过一定阈值的时候,我们就可以说当前按键被按下去,或者是松开了。

当然在等待超时的过程中,还有可能发生反转,没有关系,重新计时即可。

4、ai生成代码

了解了去抖的基本原理之后,我们其实可以自己写代码。当然想偷懒一点的话,就可以让ai帮助我们做到这一点。比如说,告诉ai,用esp32的d12口,写一个按键响应代码,中间注意防抖处理。不出意外的话,就可以得到下面这些内容,

复制代码
#include <stdio.h>
#include "freertos/FreeRTOS.h"
#include "freertos/task.h"
#include "driver/gpio.h"

// Button Configuration
#define BUTTON_GPIO     12          // D12 for button input
#define DEBOUNCE_DELAY  50          // Debounce delay in milliseconds

// Button state variables
static bool button_pressed = false;
static uint32_t last_debounce_time = 0;

/**
 * @brief Button debounce detection function
 * @return true if button is pressed (debounced), false otherwise
 */
bool button_is_pressed(void)
{
    bool current_state = gpio_get_level(BUTTON_GPIO) == 0;  // Active LOW
    uint32_t current_time = xTaskGetTickCount() * portTICK_PERIOD_MS;
    
    // Check if button state has changed
    if (current_state != button_pressed)
    {
        last_debounce_time = current_time;
        button_pressed = current_state;
    }
    
    // Return stable state after debounce delay
    if ((current_time - last_debounce_time) > DEBOUNCE_DELAY)
    {
        return button_pressed;
    }
    
    return false;
}

/**
 * @brief Button task - monitors button state with debounce
 */
void button_task(void *arg)
{
    // Configure GPIO pin for button
    gpio_config_t io_conf = {
        .pin_bit_mask = (1ULL << BUTTON_GPIO),
        .mode = GPIO_MODE_INPUT,
        .pull_up_en = GPIO_PULLUP_ENABLE,    // Enable internal pull-up resistor
        .pull_down_en = GPIO_PULLDOWN_DISABLE,
        .intr_type = GPIO_INTR_DISABLE,      // No interrupt
    };
    gpio_config(&io_conf);

    printf("Button Detection Task Started\n");
    printf("Button GPIO: %d (D12)\n", BUTTON_GPIO);
    printf("Debounce Delay: %dms\n", DEBOUNCE_DELAY);
    printf("Button is Active LOW (press to trigger)\n\n");

    bool last_button_state = false;

    while (1)
    {
        bool current_button_state = button_is_pressed();
        
        // Detect button press event
        if (current_button_state && !last_button_state)
        {
            printf("Button Pressed!\n");
        }
        
        // Detect button release event
        if (!current_button_state && last_button_state)
        {
            printf("Button Released!\n");
        }
        
        last_button_state = current_button_state;
        
        // Small delay to reduce CPU usage
        vTaskDelay(10 / portTICK_PERIOD_MS);
    }
}

void app_main(void)
{
    printf("ESP32 Button Detection Demo with Debounce\n\n");

    // Start button detection task
    xTaskCreate(button_task, "button_task", 2048, NULL, 5, NULL);
}

5、测试和验证

老规矩,拿到代码之后,首先编译一下,看看能不能编译过。没有的话,就继续改进。接着,把编译好的image烧入到板子里面,观察结果是否符合预期。最后,就是需要自己分析一下这边的代码,看看有没有需要查漏补缺的地方,本身软件的完备性够不够。这样,基本的按键代码就做好了。

相关推荐
JustNow_Man1 小时前
“失败后自动拉起修复 Agent”的闭环流水线
前端·人工智能·chrome·python
2601_957879331 小时前
企业矩阵系统建设实践:从账号管理到AI内容协同
大数据·人工智能·矩阵系统·数字化运营
我爱cope1 小时前
【Agent智能体10 | 反思设计模式-AI数据分析的可视化实战】
人工智能·设计模式·数据分析
2601_957882241 小时前
矩阵系统在企业内容管理与数字获客中的实践分析
人工智能·矩阵系统·企业数字化运营
霍格沃兹测试学院-小舟畅学1 小时前
接口自动化测试的下一个十年:从脚本到Skills,让AI学会“如何测”
java·前端·人工智能
暴躁小师兄数据学院1 小时前
【AI大模型应用开发工程师特训笔记】第04讲(第10章):Python 高阶编程
人工智能
T_Wang_Lab1 小时前
跨领域语义漂移的双视角量化框架:基于知识图谱邻居的Jaccard方法与跨域对齐的Word2Vec方法的系统比较与联合诊断
人工智能·知识图谱·word2vec
Cx330❀2 小时前
【Qt 核心机制篇】深度解析 Qt 信号与槽(Signals & Slots)机制:从底层原理、实战演练到 Lambda 进阶
linux·开发语言·c++·人工智能·qt·ubuntu
碳基硅坊2 小时前
从“几何缩微“到“时间缩微“ 华为韬定律开启芯片演进新赛道
人工智能·韬定律·时间缩微