ESP32学习笔记(37)——搭建ESP-ADF(乐鑫音频开发框架)

一、简介

ESP-ADF 以最全面的方式支持 Espressif 系统 SoC 音频应用程序的开发。使用 ESP-ADF ,您可以轻松地添加功能,开发从简单到复杂的音频应用程序:

  • 音乐播放器或录音机支持音频格式:如MP3、AAC、FLAC、WAV、OGG、OPUS、AMR、TS、EQ、Downmixer、Sonic、ALC、G.711等。
  • 播放音乐来源:HTTP,HLS(HTTPLive流),SPASS,SD Card,A2DP-Source,A2DP-Sink,HFP等等。
  • 整合媒体服务:如DLNA、VoIP等。
  • 网络收音机
  • 语音识别和与在线服务的集成:如Alexa,DuerOS等。

ESP-ADF 提供一系列 API 组件,包括音频流、编解码器和以音频管道组织的服务,所有这些组件都通过媒体 HAL 与音频硬件集成,并与 ESP32 上的外围设备集成。

1.1 官方资料

乐鑫音频应用开发指南

二、安装ESP-IDF

查看 ESP32学习笔记(1)——搭建环境、编译烧写(Windows+VS Code)
如果已安装,可跳过

三、安装ESP-ADF

3.1 获取ESP-ADF

打开命令提示符并运行以下命令:

cd %userprofile%\esp
git clone --recursive https://github.com/espressif/esp-adf.git

等待clone完成后,再打开esp-adf目录下的.gitsubmodules文件,可以看到该目录下有三个子模块仓库:

  • idf模块
  • esp-adf-libs模块:adf音频库
  • esp-sr模块:识别语音库
[submodule "esp-idf"]
	path = esp-idf
	url = https://gitclone.com/github.com/espressif/esp-idf
[submodule "components/esp-adf-libs"]
	path = components/esp-adf-libs
	url = https://gitclone.com/github.com/espressif/esp-adf-libs
[submodule "components/esp-sr"]
	path = components/esp-sr
	url = https://gitclone.com/github.com/espressif/esp-sr.git

%userprofile%\esp\esp-adf\components 目录下执行:

git clone https://gitclone.com/github.com/espressif/esp-adf-libs
git clone https://gitclone.com/github.com/espressif/esp-sr.git

3.2 设置ESP-ADF的路径

工具链程序使用 ADF_PATH 环境变量访问 ESP-ADF 。此变量应在您的 PC 上设置,否则项目将无法构建。

set ADF_PATH=%userprofile%\esp\esp-adf


需要注意的是,在每次打开cmd之后要设置ADF_PATH

还有一劳永逸的方法:
右键电脑属性→高级系统设置→环境变量→添加ADF_PATH

要确保 ADF_PATH 已正确设置,请运行:

echo %ADF_PATH%

应该返回 ESP-ADF 目录的路径:

四、编译

  1. 打开 ESP-IDF Command Prompt (cmd.exe)
  2. 进入例程目录:
cd esp\esp-adf\examples\get-started\play_mp3_control
  1. 进行编译
idf.py build
  1. 编译完成

五、烧写

5.1 编译环境中烧写

  1. 烧录前先配置模组的flash大小:
    输入命令 idf.py menuconfig 打开配置界面

进入Serial flasher config,按需将 Flash size 改为自己的大小。比较常用的两个模组:安信可ESP-32S乐鑫ESP32-WROOM-32,flash 都是 4MB。连续按 Esc 退出,按 s 保存。

  1. 查看端口号
    开发板连接电脑。设备管理器查看开发板的端口号 COM22

  2. 烧录执行

idf.py -p PORT flash

其中PORT是连接开发板的端口。如COM22,命令为idf.py -p COM22 flash

这将编译应用程序和所有 ESP_IDF 组件,生成引导加载程序,分区表和应用程序二进制文件,并将这些二进制文件闪存到 ESP32 板上。

esptool.py v3.0
Generated C:/Users/neldtv/esp/esp-idf/examples/get-started/hello_world/build/bootloader/bootloader.bin
[783/784] Generating binary image from built executable
esptool.py v3.0
Generated C:/Users/neldtv/esp/esp-idf/examples/get-started/hello_world/build/hello-world.bin
[783/784] cmd.exe /C "cd /D C:\Users\neldtv\esp\esp-idf\co...eldtv/esp/esp-idf/components/esptool_py/run_esptool.cmake"
esptool.py --chip esp32 -p COM22 -b 460800 --before=default_reset --after=hard_reset write_flash --flash_mode dio --flash_freq 40m --flash_size 4MB 0x8000 partition_table/partition-table.bin 0x1000 bootloader/bootloader.bin 0x10000 hello-world.bin
esptool.py v3.0
Serial port COM22
Connecting........_____....._____....._____....._____....._____....._____....._____

我用的是 ESP32-LyraT V4.3 开发板,出现Connecting的时候按住 Boot 键,再按一下 RST 键,进入烧录模式。

然后,出现了超时,一直烧录不成功:

然后我到 CP210x USB to UART Bridge VCP Drivers 上,下载安装驱动 CP210x Universal Windows Driver v10.1.10 之后就能下载了

  1. 下载完成

  1. 串口调试
idf.py -p PORT monitor

其中PORT是连接开发板的端口。如COM22,命令为idf.py -p COM22 monitor

5.2 烧录工具烧写

flash_download_tool_v3.8.5
链接:https://www.espressif.com/zh-hans/support/download/other-tools
然后按照 idf.py -p COM22 monitor 中提示的文件和烧录地址


• 由 Leung 写于 2021 年 7 月 22 日

• 参考:ESP32 ADF windows开发环境搭建 适配ADF到ESP32A1S

### VSCode 中 C 语言自动补全代码的配置 为了使 Visual Studio Code (VSCode) 支持 C 语言的自动补全功能,安装并配置合适的扩展程序至关重要。通过这些工具,开发者可以获得更高效的编码体验。 #### 安装必要的扩展 推荐安装由 Microsoft 提供的官方 `C/C++` 扩展包[^1]。此扩展不仅提供了语法高亮显示,还包括 IntelliSense 功能——即智能感知特性,它能够提供上下文敏感的帮助信息以及参数提示等功能来增强编程效率。 ```json { "editor.quickSuggestions": { "other": true, "comments": false, "strings": false }, "C_Cpp.intelliSenseEngine": "Default", "C_Cpp.autocomplete": "Detailed" } ``` 上述 JSON 片段展示了部分可调整设置项以优化 C/C++ 的开发环境[^4]。具体来说: - `"editor.quickSuggestions"` 控制着何时应触发快速建议; - `"C_Cpp.intelliSenseEngine"` 和 `"C_Cpp.autocomplete"` 则用于指定 IntelliSense 引擎的选择及其完成模式。 #### 配置编译器路径 对于 Windows 用户而言,在大多数情况下,默认会寻找 MinGW 或 Cygwin 这样的本地 GCC 编译器实例;然而,有时可能需要显式定义其位置以便正确解析头文件和其他依赖关系。这可以通过修改 `.vscode/c_cpp_properties.json` 文件实现: ```json { "configurations": [ { "name": "Win32", "includePath": ["${workspaceFolder}/**"], "defines": [], "compilerPath": "path/to/your/compiler/gcc.exe", // 替换为实际路径 "intelliSenseMode": "${default}" } ], "version": 4 } ``` 以上配置片段中的 `"compilerPath"` 字段需指向已安装好的 GNU Compiler Collection (GCC) 可执行文件的位置。 #### 解决潜在问题 当遇到自动补全失效的情况时,除了确认基本配置无误外,还需排查是否存在其他因素干扰正常运作,例如第三方插件冲突或是特定版本更新带来的 bug 等情况[^3]。此时可通过禁用不必要的附加组件或回滚至稳定版来进行调试。
评论 6
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

Leung_ManWah

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

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

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

打赏作者

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

抵扣说明:

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

余额充值