ESP-IDF
本章节包含以下部分,请按需阅读:
ESP-IDF 入门教程
初次接触 ESP32 ESP-IDF 开发,想要快速上手?我们为您准备了一套通用的 入门教程。
- 第0节 认识 ESP32
- 第1节 搭建环境
- 第2节 运行实例
- 第3节 创建项目
- 第4节 使用组件
- 第5节 调试程序
- 第6节 FreeRTOS
- 第7节 驱动外设
- 第8节 Wi-Fi 编程
- 第9节 BLE 编程
请注意:该教程使用 ESP32-S3-Zero 作为教学示例,所有硬件代码均基于其引脚布局。在动手实践前,建议您对照手中的开发板引脚图,确认引脚配置无误。
配置 ESP-IDF 开发环境
对于 ESP32-C6-Touch-AMOLED-1.43 开发板,需要使用 ESP-IDF V5.5.0 以上版本。
以下内容以 Windows 系统为例,使用 VS Code + ESP-IDF 扩展 的方式进行开发。Mac/Linux 用户请参考 官方说明。
安装 ESP-IDF 开发环境
-
前往 ESP-IDF Installation Manager 下载 ESP-IDF 安装管理器。这是乐鑫最新推出的跨平台安装工具,下文将演示如何使用其离线安装功能。
在页面中点击 Offline Installer 标签,然后在筛选栏中选择 Windows 操作系统和你要安装的版本。

确认选择无误后,点击下载按钮。浏览器将自动同时下载两个文件:一个是 ESP-IDF 离线整合包(.zst),另一个是 ESP-IDF 安装器(.exe)。

请耐心等待两个文件下载完成。
-
下载完成后,双击运行 ESP-IDF 安装器(eim-gui-windows-x64.exe)。
启动后,可在右上角将界面语言切换为中文。

安装工具会自动检测同一目录下是否存在离线整合包。点击 从存档安装。

接下来,选择安装路径。建议使用默认路径;若需自定义,请确保路径中不包含中文或空格。确认无误后,点击 开始安装。

-
当看到如下界面时,表示 ESP-IDF 已安装成功。

-
建议同时安装驱动程序。点击 完成安装,然后点击 安装驱动程序。

安装 Visual Studio Code 与 ESP-IDF 扩展
-
下载并安装 Visual Studio Code。
-
安装时建议勾选 通过 Code 打开操作添加到 Windows 资源管理器文件上下文菜单,以便快速打开项目文件夹。
-
在 VS Code 中,点击侧边活动栏中的
扩展图标(或使用快捷键 Ctrl + Shift + X)打开 扩展 视图。
-
在搜索框中输入 ESP-IDF,找到 ESP-IDF 扩展并点击安装。

-
当 ESP-IDF 扩展版本 ≥ 2.0 时,扩展会自动检测并识别上述步骤中安装的 ESP-IDF 环境,无需手动配置。
示例程序
| 示例程序 | 基础例程说明 | 依赖库 |
|---|---|---|
| 01_ADC_Test | 获取锂电池的电压值 | - |
| 02_I2C_PCF85063 | 打印RTC芯片的实时时间 | SensorLib |
| 03_I2C_QMI8658 | 打印IMU发出来的原始数据 | SensorLib |
| 04_SD_Card | 加载显示SD卡的信息 | - |
| 05_WIFI_AP | 设置为AP模式,可获取接入设备的IP地址 | - |
| 06_WIFI_STA | 设置为STA模式,可接入WiFi获取IP地址 | - |
| 07_BATT_PWR_Test | 单独使用锂电池供电时,通过PWR按键控制电源 | - |
| 08_Audio_Test | 扬声器播放麦克风录到的声音 | - |
| 09_LVGL_V8_Test | LVGLV8例程 | LVGL V8.3.11 |
| 10_LVGL_V9_Test | LVGLV9例程 | LVGL V9.3.0 |
| 11_FactoryProgram | 综合示例 | LVGL V8.3.11 |
01_ADC_Test
【程序说明】
- 通过 GPIO 连接的模拟量电压经过 ADC 转换成数字量,然后通过计算得到实际的锂电池电压,并打印到终端。
【硬件连接】
- 使用 USB 线把板子接入电脑
【代码分析】
adc_bsp_init(void):初始化 ADC1,包括创建 ADC 单次触发单元并配置 ADC1 的通道 0。adc_get_value(float *value,int *data):读取 ADC1 通道 0 的值,并根据参考电压和分辨率计算出对应的电压值存储在传入的指针指向的位置,如果读取失败则存储 0。adc_example(void* parameter):初始化 ADC1 后,创建一个 ADC 任务,该任务每隔 1 秒读取一次 ADC 的值,通过读取的 ADC 原始值计算出系统的电压。
【运行效果】
-
程序编译下载完成,打开串口监控可以看到打印输出的 ADC 的值和电压,如下图所示:

02_I2C_PCF85063
【程序说明】
- 通过 I2C 协议,分别对 PCF85063 芯片进行初始化、设置时间、间隔读取时间,然后打印到终端。
【硬件连接】
- 使用 USB 线把板子接入电脑
【代码分析】
void i2c_rtc_loop_task(void *arg):创建一个 RTC 任务来实现 RTC 功能,每隔 1 秒读取一次 RTC 芯片的时钟,然后输出到终端。
【运行效果】
-
打开串口监控,可以看到打印输出的 RTC 时间,如下图所示:

03_I2C_QMI8658
【程序说明】
- 通过 I2C 协议,对 QMI8658 芯片进行初始化设置,然后每隔 200ms 读取对应的姿态信息打印到终端。
【硬件连接】
- 使用 USB 线把板子接入电脑
【代码分析】
void i2c_qmi_loop_task(void *arg):创建一个 QMI 任务来实现获取姿态信息,在任务中读取并打印加速度计、陀螺仪数据,并将获取的结果输出到串口控制台,间隔200ms 。
【运行效果】
-
打开串口监控,可以看到打印输出的 IMU 发出来的原始数据(欧拉角需要自己转换),如下图所示:

04_SD_Card
【程序说明】
- 通过 SDSPI 方式驱动 SD 卡,成功挂载之后把 SD 卡信息打印到终端。
【硬件连接】
- 上电之前先给板子装上 FatFs 格式的 SD 卡
【代码分析】
sdcard_init(void):使用 SDSPI 方式初始化 SD 卡。loop():测试 SD 卡读写功能,需要取消#define sdcard_write_Test宏定义的注释。
//#define sdcard_write_Test
【运行效果】
-
点击串口监控设备,可以看到输出的 SD 卡的信息,practical_size 是 SD 卡的实际容量,如下图所示:

05_WIFI_AP
【程序说明】
- 该示例可将开发板设置为热点,允许手机或其他处于 STA 模式的设备连接到开发板。
【硬件连接】
- 使用 USB 线把板子接入电脑
【代码分析】
-
在
05_WIFI_AP.ino文件找到ssid和password,然后手机或其他处于 STA 模式的设备即可使用该 ssid 和 password 连接到开发板。const char *ssid = "ESP32_AP";
const char *password = "12345678";
【运行效果】
-
烧录完程序,打开串口终端,如果设备连接成功热点之后,会输出该设备的MAC地址,如图:

06_WIFI_STA
【程序说明】
- 该示例可将开发板配置为 STA 设备,以连接路由器,从而接入系统网络。
【硬件连接】
- 使用 USB 线把板子接入电脑
【代码分析】
-
在
06_WIFI_STA.ino文件找到ssid和password,然后将其修改为当前环境中可用路由器的 SSID 和 Password。const char *ssid = "you_ssid";
const char *password = "you_password";
【运行效果】
-
烧录完程序,打开串口终端,如果设备连接成功热点之后,会输出所获取的 IP 地址,如图:

07_BATT_PWR_Test
【程序说明】
- 使用锂电池供电的情况下,演示如何通过 PWR 按键控制系统的电源。
【硬件连接】
- 使用锂电池为开发板供电
【代码分析】
setup_ui(lv_ui *ui):初始化 ui 界面,使得控制可视化。esp_io_expander_new_i2c_tca9554():初始化锂电池控制 IO 端口。user_button_init():初始化按键以及各类触发事件。example_button_task(void* parmeter):等待按键事件触发的任务。
【运行效果】
-
程序烧录完成后,断开 USB 供电,接入锂电池,通过长按 PWR 按键进行开机,如图:
提示- 长按 PWR 按键,等待屏幕显示 "Power on succeeded" ,表示启动成功,松开按键即可
- 再次长按 PWR 按键,等待屏幕显示 "Power on failed" ,表示电源关闭成功,松开按键即可
08_Audio_Test
【程序说明】
- 演示如何获取麦克风的数据,然后再通过扬声器播放。
【硬件连接】
- 使用 USB 线把板子接入电脑
- 连接扬声器到板载 MX1.25 2PIN 扬声器接口
【代码分析】
i2c_master_Init():初始化 I2C 总线。esp_io_expander_new_i2c_tca9554():初始化功放 CTRL 控制 IO 端口。esp_codec_dev_set_out_vol():设置播放时的声音大小。esp_codec_dev_set_in_gain():设置录音的增益。
【运行效果】
-
程序烧录完成后,对着麦克风说话,扬声器会自动播放录到的声音,该示例没有 UI 显示:
提示- 如果感觉播放声音比较小,优先使用 "esp_codec_dev_set_out_vol" 调大播放音量
- 调大播放音量满足不了的情况下,可以使用 "esp_codec_dev_set_in_gain" 调大录音时的增益
09_LVGL_V8_Test
【程序说明】
- 通过移植 LVGL V8,在屏幕上实现一些多功能的 GUI 界面。
【硬件连接】
- 使用 USB 线把板子接入电脑
【代码分析】
-
如果需要旋转 90 度显示,可以在
user_config.h文件找到#define EXAMPLE_Rotate_90宏定义,取消注释即可。 -
如果需要进行背光测试,可以在
user_config.h文件找到#define Backlight_Testing宏定义,取消注释即可。//#define Backlight_Testing
//#define EXAMPLE_Rotate_90
【运行效果】
-
程序烧录完成后,设备的运行效果如下:

10_LVGL_V9_Test
【程序说明】
- 通过移植LVGL V9,在屏幕上实现一些多功能的 GUI 界面。
【硬件连接】
- 使用 USB 线把板子接入电脑
【代码分析】
-
如果需要旋转 90 度显示,可以在
user_config.h文件找到#define EXAMPLE_Rotate_90宏定义,取消注释即可。 -
如果需要进行背光测试,可以在
user_config.h文件找到#define Backlight_Testing宏定义,取消注释即可。//#define Backlight_Testing
//#define EXAMPLE_Rotate_90
【运行效果】
-
程序烧录完成后,设备的运行效果如下:

11_FactoryProgram
【程序说明】
- 综合性工程,简单测试板载硬件功能,也可以直接使用我们提供的 BIN 固件烧录。
【硬件连接】
- 使用 USB 线把板子接入电脑
【代码分析】
ContsGroups = xEventGroupCreate(); //创建事件组,用于任务间同步
Serial.begin(115200); //初始化串口通信,波特率115200
Tca9554_Init(); //初始化TCA9554 GPIO扩展芯片
display = new DisplayPort(i2cbus, 466, 466); //创建显示端口实例,分辨率466x466
display->DisplayPort_TouchInit(); //初始化显示屏触摸功能
Lvgl_PortInit(*display); //初始化LVGL图形库端口
Adc_PortInit(); //初始化ADC端口
Custom_ButtonInit(); //初始化自定义按键
I2cRtcSetup(&i2cbus, 0x51); //初始化I2C RTC时钟芯片,地址0x51
Set_I2cRtcTime(2026, 1, 1, 0, 0, 0); //设置RTC时间为2026年1月1日00:00:00
I2cQmiSetup(&i2cbus, 0x6b); //初始化I2C IMU传感器,地址0x6b
codecport = new CodecPort(i2cbus,"C6_AMOLED_1_43"); //创建音频编解码器端口实例
【运行效果】
-
显示屏从红、绿、蓝三种颜色进行跳转(跳转间隔 1.5 秒),如图:

-
系统跑完上面的颜色之后会自动进入板载硬件信息界面,如图:
提示- 可以显示 ESP32C6 叠封的 Flash
- 显示接入 SD 卡的实际容量
- 显示接入锂电池电压
- 实时显示 RTC 时间和 QMI 姿态数据
- 扫描周围的蓝牙和 wifi 设备
-
在板载硬件信息界面单击 BOOT 按键进入 Touch 功能界面,如图:

-
再次单击 BOOT 按键,退出 Touch 的功能界面,进行麦克风收音和扬声器播放音乐功能:
提示- 对着麦克风说话,扬声器会自动播放收录的声音
- 按住 BOOT 按键,可以播放音乐,松开停止
-
检验 SD 卡读写功能,如图:
提示- 双击 BOOT 按键即可检验
-
往左滑动,进入到设置 AMOLED 背光界面,如图:

-
单独使用锂电池供电,PWR 按键控制电源:
提示- 长按 PWR 按键打开系统电源,再次长按 PWR 可以关机系统电源