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

ESP-IDF button 组件介绍

引言Button 是嵌入式系统中最基础的输入元素之一但要正确处理按钮输入需要对消抖、事件检测以及时间控制等细节进行细致处理。乐鑫推出 button 组件 —— 一个功能完善且稳定可靠的 ESP-IDF 按钮驱动组件可帮助您在项目中更轻松地实现按钮处理。button 组件为 ESP32 项目中的物理按钮管理提供了一个完整的解决方案既支持基于 GPIO 的按钮也支持基于 ADC 的按钮矩阵。Button 组件是 ESP Component Registry 上众多组件之一。ESP Component Registry 是一个集中式平台用于托管可复用的 ESP-IDF 软件组件。它通过提供预构建、经过测试的库来简化开发流程这些库可以轻松集成到应用中使开发者能够利用社区验证过的解决方案加速项目开发。关键特性button 组件提供了多项强大功能多种按钮类型支持支持 GPIO 按钮以及 ADC 按钮矩阵事件检测提供完整的按钮事件处理机制包括按下、释放、长按以及重复按压等消抖处理内置软件消抖机制可有效消除误触发低功耗支持针对电池供电应用进行了优化回调机制提供易于使用的按钮事件回调机制线程安全可安全应用于多线程环境丰富的事件类型共支持 11 种不同的按钮事件包括按钮按下、释放以及重复按压单击、双击以及多击检测长按开始、长按保持以及长按释放事件重复按压结束以及按压结束通知应用示例button 组件可帮助开发者在多种应用场景中构建响应迅速且可靠的按钮交互界面智能灯控通过单击实现开关控制双击调节亮度长按选择灯光颜色设备菜单导航通过按钮事件在设备设置和菜单中进行导航并支持直观的多次点击交互IoT网关配置通过长按触发 Wi-Fi 配网模式或通过特定按钮组合重置设备设置可穿戴设备交互在空间受限的设备中通过单个按钮实现多种功能映射工业控制面板通过消抖机制实现安全可靠的按钮控制确保设备操作稳定家庭自动化中心通过简单的按钮操作和可配置的时间参数来管理复杂的自动化场景基础示例下面的示例展示了如何使用 GPIO 按钮来配置 button 组件。我们将逐步拆解每个部分以便理解其实现方式。该示例创建了一个按钮应用用于检测GPIO 9上的多种按钮事件。代码会初始化按钮硬件、配置不同按压类型的时间参数并注册回调函数。当检测到对应的按钮事件时相应的回调函数将被执行并在控制台输出日志用于监控和调试。本示例使用 ESP32-C3-DevKit-RUST-2 开发板。在该开发板上GPIO 9 对应按钮引脚但您也可以根据实际硬件配置修改 GPIO 引脚编号。硬件ESP32-C3-DevKit-RUST-2 开发板内置了一个连接到 GPIO9 的按钮。该按钮通过外部 10kΩ 上拉电阻连接在GPIO 引脚与地之间从而将其配置为低电平有效 (active-low) 输入。当按钮被按下时GPIO9 被拉至地逻辑低电平当按钮释放时上拉电阻会将该引脚拉回 VCC逻辑高电平。ESP32-C3-DevKit-RUST-2 上的按钮原理图注意ESP32-C3 的 GPIO9 是一个启动配置 (boot strapping) 引脚用于进入下载模式。请避免在设备启动过程中按下该按钮以防止设备意外进入下载模式。组件安装您可以使用IDF Component Manager将 button 组件轻松添加到 ESP-IDF 项目中idf.py add-dependency espressif/button*该命令将安装 button 组件的最新可用版本。或者您也可以在idf_component.yml文件中手动添加依赖dependencies: espressif/button: ^4.1.5注意在本文发布时当前版本为4.1.5。版本规范^4.1.5表示依赖将使用4.1.5 或任何更新且兼容的版本如果可用。步骤 1包含所需头文件首先包含按钮处理所需的头文件#include iot_button.h #include button_gpio.h步骤 2定义 GPIO 与基础配置设置 GPIO 引脚并配置日志// Define button GPIO and active level #define BUTTON_IO_NUM 9 // GPIO number for the button #define BUTTON_ACTIVE_LEVEL 0 // Active level for the button (0 for active low, 1 for active high) static const char *TAG BUTTON;步骤 3创建事件回调函数定义在按钮事件发生时触发的回调函数// Callback functions for button events static void button_single_click_event_cb(void *arg, void *data) { ESP_LOGI(TAG, Button single click!); } static void button_double_click_event_cb(void *arg, void *data) { ESP_LOGI(TAG, Button double click!); } static void button_long_press_event_cb(void *arg, void *data) { ESP_LOGI(TAG, Button long press!); } static void button_repeat_event_cb(void *arg, void *data) { ESP_LOGI(TAG, Button press repeat!); }当检测到对应的按钮事件时这些回调函数会由 button 组件自动调用。在本示例中每个回调函数仅用于在控制台输出日志信息以作演示。在实际应用中您应将这些日志语句替换为应用逻辑例如在单击回调中切换 LED 状态在双击回调中调节亮度等级在长按回调中触发 Wi-Fi 配网流程其中arg 参数可用于向回调函数传递用户自定义的上下文数据而 data 参数则提供来自 button 组件的事件相关信息。步骤 4配置按钮时间参数在 app_main() 函数中创建按钮配置并设置时间参数void app_main(void) { // Create button configurations const button_config_t btn_cfg { .long_press_time 5000, // Long press time in milliseconds .short_press_time 200, // Short press time in milliseconds };时间配置用于定义组件如何区分不同类型的按钮按压。short_press_time 参数用于设置按钮被识别为有效按压所需的最短持续时间单位为毫秒。该参数实际上充当了消抖阈值。在本示例中200ms可以过滤机械抖动和误触。long_press_time 参数用于确定触发长按事件所需的持续时间。在本示例中该值设置为5000ms5 秒。这些时间参数可以根据应用需求进行调整对于需要快速响应的界面可以使用更短的时间对于需要避免误触的应用可以使用更长的时间步骤 5配置 GPIO 设置为按钮设置 GPIO 相关配置const button_gpio_config_t btn_gpio_cfg { .gpio_num BUTTON_IO_NUM, .active_level BUTTON_ACTIVE_LEVEL, .disable_pull false, };active_level 参数用于定义表示按钮被按下的逻辑电平。在低电平有效 (0) 配置中当按钮按下时会将 GPIO 拉低到地这是最常见的配置方式通常与上拉电阻一起使用。在这种情况下按下按钮时 GPIO 读取为低电平 (0)释放按钮时 GPIO 读取为高电平 (1)在高电平有效 (1) 配置中按钮按下时会将 GPIO 连接到 VCC通常与下拉电阻一起使用。在这种情况下按下按钮时 GPIO 读取为高电平 (1)释放按钮时 GPIO 读取为低电平 (0)disable_pull 参数用于控制是否禁用内部上拉或下拉电阻。将其设置为 false 表示启用内部拉电阻这在大多数应用中是推荐的设置因为它可以确保在按钮未被按下时 GPIO 仍然保持明确的逻辑电平。步骤 6创建按钮设备使用上述配置初始化按钮设备// Button handle button_handle_t btn; // Create a new button device esp_err_t ret iot_button_new_gpio_device(btn_cfg, btn_gpio_cfg, btn);步骤 7注册事件回调为不同的按钮事件注册回调函数// Register callback for button press ret iot_button_register_cb(btn, BUTTON_SINGLE_CLICK, NULL, button_single_click_event_cb, NULL); ESP_ERROR_CHECK(ret); ret iot_button_register_cb(btn, BUTTON_DOUBLE_CLICK, NULL, button_double_click_event_cb, NULL); ESP_ERROR_CHECK(ret); ret iot_button_register_cb(btn, BUTTON_LONG_PRESS_UP, NULL, button_long_press_event_cb, NULL); ESP_ERROR_CHECK(ret); ret iot_button_register_cb(btn, BUTTON_PRESS_REPEAT, NULL, button_repeat_event_cb, NULL); ESP_ERROR_CHECK(ret); }该示例展示了按钮配置与事件处理的几个关键方面。GPIO9 被配置为低电平有效逻辑即按钮按下时会将 GPIO 拉低。时间参数被设置为5 秒检测长按200 毫秒检测短按从而支持多种交互方式。该组件支持多种事件类型包括单击双击长按重复按压所有事件均通过回调系统进行管理。应用中针对不同按钮交互的具体处理逻辑应在相应的回调函数中实现。例如在单击回调中切换 LED 状态在长按回调中触发 Wi-Fi 配网通过 ESP_ERROR_CHECK() 进行错误检查可以确保每个回调注册成功而在事件回调中输出日志则能够在控制台提供清晰的信息便于调试和验证按钮行为。完整源代码该示例的完整源代码可在 developer-portal-codebase 仓库中获取。总结如果您计划在下一次 ESP-IDF 项目中使用按钮建议集成espressif/button 组件。这样可以将精力集中在应用逻辑上而无需处理底层按钮管理的复杂细节。该组件提供完善的事件检测系统包括单击双击长按重复按压能够满足现代嵌入式应用对交互灵活性的需求。借助内置消抖机制、线程安全设计以及对 GPIO 与 ADC 按钮矩阵的支持开发者可以轻松实现复杂的按钮交互而无需从零开始开发。无论您是在开发智能家居设备、IoT 网关还是工业控制面板espressif/button 组件都能处理可靠按钮输入检测的复杂性使您能够专注于打造优秀的用户体验。该组件通过 ESP Component Registry 提供易于集成并具备官方 Espressif 组件所提供的可靠性与技术支持。进一步学习如果您希望深入了解 GPIO 基础以及其与按钮组件的工作方式可以参考以下教程ESP-IDF 教程系列GPIO 入门 - 第 1 部分ESP-IDF 教程系列GPIO 入门 - 第 2 部分参考资源ESP Component Registry 上的 button 组件ESP Component Registry 文档ESP32-C3-DevKit-RUST-2 文档什么是 ESP Component RegistryGitHub - button 仓库

相关文章:

ESP-IDF button 组件介绍

引言 Button 是嵌入式系统中最基础的输入元素之一,但要正确处理按钮输入,需要对消抖、事件检测以及时间控制等细节进行细致处理。乐鑫推出 button 组件 —— 一个功能完善且稳定可靠的 ESP-IDF 按钮驱动组件,可帮助您在项目中更轻松地实现按…...

一条指令,是怎么被机器读懂的

你每次敲下一行代码,按下运行,屏幕上出现结果。 这个过程,看起来很自然,自然得像呼吸一样。 但在这个过程里,有一件事情发生得悄无声息,大多数人从来没有想过: 你写的那行代码,最终变…...

模拟PPG生物信号,利用短时傅里叶变换滤波,提取心率

1、利用短时傅里叶变换滤波,提取心率def test06():import numpy as npimport matplotlib.pyplot as pltfrom scipy import signalfrom scipy.signal import find_peaks# ---------- 参数设置 ----------fs 1000 # 采样率 (Hz)duration 10 # 信号时长 (秒)t np.…...

软件测试入门封神指南!从理论到实战,核心知识点一篇全覆盖

目录零基础也能看懂的测试体系课,搞定开发模型、测试流程、用例设计、BUG管理全链路一、先搞懂软件开发流程!测试人必知的4大经典模型1. 瀑布模型2. V模型3. W模型4. 快速原型模型二、软件测试全流程!9个核心步骤,一步都不能错1. …...

C语言从入门到进阶——第15讲:深入理解指针(5)

文章目录1. 回调函数是什么?2. qsort使用举例2.1 使用qsort函数排序整型数据2.2 使用qsort排序结构数据3. qsort函数的模拟实现1. 回调函数是什么? 回调函数就是一个通过函数指针调用的函数。 如果你把函数的指针(地址)作为参数传递给另一个函数,当这个指针被用来…...

基于跨模态医学图像生成模型的早期肺癌风险评估研究-(resnet)-大数据深度学习算法毕设毕业设计项目-含完整论文源码

博主介绍:👉全网个人号和企业号粉丝40W,每年辅导几千名大学生较好的完成毕业设计,专注计算机软件领域的项目研发,不断的进行新技术的项目实战👈 ⭐️热门专栏推荐订阅⭐️ 订阅收藏起来,防止下次找不到 &am…...

【C++项目】从零实现高并发内存池(一):核心原理与设计思路

一:什么是内存池? 1. 池化技术 定义:程序先向系统申请过量资源,自己管理备用,避免频繁申请系统资源的开销。核心思想:提前申请 → 自行管理 → 快速复用,提升运行效率。常见应用:内…...

深度学习野外环境下野生动物检测(YOLOv12/v11/v8/v5模型+数据集)(源码+lw+部署文档+讲解等)

摘要 随着全球生态系统的不断变化,野生动物的保护和监测已成为生态学和环境科学领域的重要任务。传统的野生动物监测方法如人工观察和固定摄像头拍摄,存在效率低、成本高和环境适应性差等问题。近年来,深度学习技术的快速发展为野生动物的自动…...

全面理解MySQL架构

目录学前目标一条查询SQL是如何执行的mysql组成架构客户端服务端完整执行流程一条更新SQL是如何执行的学前目标 掌握 MySQL 整体架构划分,清晰区分 Server 层和存储引擎层的功能与核心组件; 理解一条 SQL 查询 / 更新语句的完整执行流程; 掌握…...

android java设置控件不可见+高度=0

holder.im_plan_pic_in_plan_item.setVisibility(View.GONE);就这样就可以了,不会有任何高度:This view is invisible, and it doesnt take any space for layout purposes. Use with setVisibility and android:visibility. 可以看到这个图片是完全没有…...

从发布到可见:让自定义业务对象真正落地到 SAP Fiori 的完整路径

在很多项目里,开发人员完成 Custom Business Object 建模、点击 Publish 之后,往往会产生一种错觉:业务对象已经生成了,应用应该马上就能给业务用户使用。可一回到 launchpad,却发现既搜不到应用,也看不到磁贴,甚至连进入页面的入口都没有。真正的原因并不复杂:Publish…...

从 Key User 扩展到可运输交付:彻底吃透 SAP Fiori 中的 Adaptation Transport Organizer

在很多团队里,业务顾问第一次接触 SAP Fiori 扩展工具时,都会有一个很直观的问题:为什么我在 Custom Fields and Logic、运行时适配,或者其他 Key User 扩展场景里做了增强,却看不到熟悉的 package 和 transport request 录入步骤?答案就在 Adaptation Transport Organiz…...

JAVA学习第二天作业笔记

题目1.能够在Java程序中使用注释:单行注释"\\"只可以注释一行,\* *\多行注释,\** *\文档注释2.能够说出变量的作用:变量就是内存中的一块区域,可以理解成一个盒子,用来装程序要处理的数据的3.能…...

氢电混合储能系统仿真(光伏,锂电池,燃料电池) 储能共直流母线 光伏储能共交流母线 储能由氢燃...

氢电混合储能系统仿真(光伏,锂电池,燃料电池) 储能共直流母线 光伏储能共交流母线 储能由氢燃料电池锂电池组成 直流母线电压稳定在800v 考虑光伏故障下系统的运行特性在新能源领域,氢电混合储能系统正逐渐成为研究的热…...

造点弯月数据

BPAdaboost模型 1、Adaboost算法是将BP神经网络作为“弱”分类器,通过不断训练BP神经网络,每次迭代更新的过程中不断更新数据的权重分布,通过Adaboost算法得到多个BP神经网络弱分类器组成的强分类器; 2、通过这个让你彻底理解和应…...

Flow3d+edem的粉末床激光增材制造熔池流动数值模拟 内容包含如下: 1该模拟资料包含粉...

Flow3dedem的粉末床激光增材制造熔池流动数值模拟 内容包含如下: 1该模拟资料包含粉床建立部分(EDEM,和Gambit软件)以及模型模拟部分Flow3D软件,全部具有视频讲解,步骤清晰,内筒详细。 2所给资料包含粉床模…...

H∞鲁棒控制入门案例(Matlab + Simulink)

H∞鲁棒控制入门案例(Matlab Simulink)✅ 第一步:Matlab 中设计 H∞ 控制器 matlab 编辑 1%% H∞鲁棒控制入门案例 - Matlab部分 2clear; clc; close all; 3 4% 1. 定义被控对象(二阶系统) 5% G(s) 1 / (s^2 2ζωn…...

【CLAUDE.md优化】从一锅炖到分层治理:我的 CLAUDE.md 重构实录

网上教你写 CLAUDE.md 的文章不少,该放什么、格式怎么写、层级怎么分,讲得都对。但看完你还是不知道一件事:**我的 CLAUDE.md 到底什么时候该拆、怎么拆、拆到什么程度。**这个问题没有标准答案,因为 CLAUDE.md 不是配置文件&…...

利用 Matlab/Simulink 平台搭建双馈风力发电机在电网中的模型 双馈风力发电机在风速变化的影响下转矩、电流、电压等参数波形变化。 适用于风电并网时对风电场影响的研究

利用 Matlab/Simulink 平台搭建双馈风力发电机在电网中的模型 双馈风力发电机在风速变化的影响下转矩、电流、电压等参数波形变化。 适用于风电并网时对风电场影响的研究对于“适用于风电场影响研究”且需要观察“风速变化下转矩、电流、电压波形”的需求,最稳健且适…...

080校园共享系统-springboot+vue

文末领取项目源码springbootvue 1.首页请文末卡片dd我获取源码...

博途1200PLC下的高效脉冲除尘控制方案研究

No.121.基于博途1200PLC的脉冲除尘控制某水泥厂除尘车间里,十几个电磁阀突然集体罢工,操作面板上红色警报闪得人头皮发麻。老张叼着半截烟头蹲在PLC柜前,嘴里嘟囔着:"这脉冲时序怕不是被狗啃了"。今天咱们就来聊聊怎么用…...

基于Matlab Simulink仿真的光伏并网最大功率点追踪(MPPT)及双闭环电压电流调节...

光伏并网 MPPT追踪光伏最大发电功率 光伏boostmpptdc-ac电压电流双闭环 两级式三相光伏并网 双PI SPWM调制 Matlab/Simlink仿真 三相L LC LCL并网逆变器 采用双闭环电压电流调节 锁相环 电网电压 并网电流同频同相 仿真正确波形 波形完美 附带参考文献光伏并网系统里&…...

2026 年 1-2 月中国大模型备案发展分析报告

一、报告核心概况2026 年 1-2 月,国家网信办持续推进生成式人工智能服务备案工作,期间共完成 48 款大模型备案,覆盖全国 16 个省级行政区及国资委监管的中央企业。此次备案大模型呈现 “区域分布多元、行业场景聚焦” 的特征,技术…...

协程学习笔记2

一、Flow通过flow异步返回多个值fun simpleFlow() flow<Int> {for (i in 1..5) {delay(1000)emit(i)} }Test fun 通过flow异步返回多个值() runBlocking {launch {for (k in 1..5) {delay(500)println("k:$k")}}delay(500)simpleFlow().collect {println(it)…...

嵌入式工程师必学(176):深入ADC

前言: 对于要理解芯片而言,不仅要理解芯片内部的模块构成,接口就是要知道接口内部结构是怎么构成的,但是每个接口功能而言,内部和外部是一个有联系有关联的系统,要一起看,电压的分配,电流的流动,电阻的匹配 ,电容的充放电。 ADC这个接口看似简单,也不简单。ADC芯片…...

和我一起学软件架构:C编译流程

引言 我们基于两个材料进行实验&#xff1a;&#xff08;一个简单的C语言代码) (GNU工具-GCC) 源代码 // hello.c #include <stdio.h> #define PI 3.14159 int main() {double radius 5.0;double area PI * radius * radius;printf("Area %f\n", area);re…...

【力扣-239. 滑动窗口最大值[特殊字符]】Python笔记

单调队列与滑动窗口算法详解滑动窗口概念滑动窗口技术用于在数组或字符串上维护一个固定大小的子区间。传统暴力解法每次滑动窗口后重新计算极值会导致O(nk)时间复杂度&#xff0c;在数据规模较大时效率低下。单调队列特性单调队列通过特殊结构保证队列元素始终有序&#xff1a…...

linux的指令(2)

find&#xff08;用于查找文件&#xff09;find目录/ -name文件名&#xff08;文件名中加*是通配符&#xff0c;如第二张图&#xff09;which 用于查找指令通常指令都是处于bin文件中&#xff08;所有指令本质上都已Linux中的一个文件&#xff09;&#xff08;is where用于少数…...

工具管理化技术工具选型与集成评估

工具管理化技术工具选型与集成评估&#xff1a;提升企业效率的关键路径 在数字化转型的浪潮中&#xff0c;技术工具的选型与集成已成为企业提升运营效率、优化资源分配的核心环节。面对市场上种类繁多的技术工具&#xff0c;如何科学评估、合理选型&#xff0c;并实现高效集成…...

Phi-3 Forest Laboratory 工具链整合:Visual Studio Code高效开发插件推荐与配置

Phi-3 Forest Laboratory 工具链整合&#xff1a;Visual Studio Code高效开发插件推荐与配置 你是不是也遇到过这种情况&#xff1a;写代码写到一半&#xff0c;突然卡在一个函数实现上&#xff0c;或者面对一段复杂的遗留代码&#xff0c;需要花半天时间去理解它的逻辑。传统…...