ESP32 ADF windows开发环境搭建 适配ADF到ESP32A1S

本文详细介绍了在ESP32A1S上搭建ADF开发环境的步骤,包括获取IDF和IDF-TOOL,安装ADF,适配ADF到ESP32A1S以及使用asr语音识别例程。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

搭建ESP32A1S的ADF开发环境

一,获取IDF和IDF-TOOL

adf是乐鑫的音频开发框架,里面有许多乐鑫的音频开发API,同时ADF是基于IDF的。
这一部分可以按照官网的教程一步一步来。
官网教程地址:ADF安装指南
首先下载esp-idf,如果是第一次使用idf,可以在官网下载一个idf工具安装器,通过这个安装器直接安装idf,同时还可以安装编译工具链。下载的速度也还可以接受。大概三十分钟就可以搞定。

本安装器可为您安装所需的交叉编译器、OpenOCD、cmake 和 Ninja 编译工具,以及一款 mconf-idf 配置工具。此外,本安装器还可在有需要时下载、运行 Python 3.7 和 Git For Windows 的安装器。本安装器还可用于下载任意 ESP-IDF 发布版本。

下载完安装器后直接运行如下(安装器运行时需要python3和git的支持):

在这里插入图片描述
选择要安装的idf的3.3版本,记住路径不要有空格。使用ADF开发时最好用3.3的idf,比较稳定不会出错
在这里插入图片描述

接下来是选择idf-tool的安装路径:
在这里插入图片描述
等个半小时左右安装完成。测试工具链能不能正常工作。我们的桌面会生成这一个cmd
在这里插入图片描述双击运行后它会自动为我们设置idf_path等编译需要的环境变量,我们直接cd到idf里examples里一个工程,例如:
D:\ESP\idf3.3\examples\get-started\hello_world
然后执行idf.py build
如果编译成功的话就说明编译工具和idf安装成功。

二,安装ADF

乐鑫把ADF放在了github,仓库地址是:https://github.com/espressif/esp-adf
这是一个带子模块的仓库,如何加速下载请参考博客提升github下载速度里带子模块的下载。
步骤:创建ESP文件夹,然后cmd,执行以下命令克隆仓库:

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

等待clone完成后,再打开esp-adf目录下的.gitmodules文件,可以看到该目录下有三个子模块仓库:
idf模块,esp-adf-libs模块:adf音频库,esp-sr:识别语音库

esp-adf-libs目录下执行:

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

esp-sr目录下执行:

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

esp-idf目录下执行:

git clone https://gitclone.com/github.com/espressif/esp-idf

以上仓库下载完成后,修改adf目录下.gitmodules的内容如下:

[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

当两个仓库下载完成后 在adf目录下cmd执行git submodule update --init这一步将两个子模块切换到当前ADF要求的版本。至此ADF已经完成安装,这时要测试一下ADF是否能编译成功。打开之前的桌面cmd,需要注意的是,在每次打开cmd之前要设置ADF_PATH
在cmd执行set ADF_PATH=你的ADF目录例如我的是:set ADF_PATH=D:\ESP\esp-adf,(路径不要有空格
或者在ESP\.espressif目录下添加该语句,如图,一劳永逸:

在这里插入图片描述

然后cd到随便ADF目录下examples下随意一个工程,与之前一样idf.py build测试能否成功通过编译。

三,适配ADF到ESP32A1S

由于ADF里是没有ESP32A1S的初始化代码的,所以需要自己添加进去。

1,首先修改esp-adf\components\audio_board目录下的三个配置文件,如下:
在这里插入图片描述
1.1,CMakeLists.txt 添加内容如下:

if (CONFIG_ESP_AI_THINKER_V2_2_BOARD)
message(STATUS "Current board name is " CONFIG_ESP_AI_THINKER_V2_2_BOARD)
list(APPEND COMPONENT_ADD_INCLUDEDIRS ./ai_thinker_audio_kit_v2_2)
set(COMPONENT_SRCS
./ai_thinker_audio_kit_v2_2/board.c
./ai_thinker_audio_kit_v2_2/board_pins_config.c
)
endif()

1.2,compoment.mk 添加如下:

ifdef CONFIG_ESP_AI_THINKER_V2_2_BOARD
COMPONENT_ADD_INCLUDEDIRS += ./ai_thinker_audio_kit_v2_2
COMPONENT_SRCDIRS += ./ai_thinker_audio_kit_v2_2
endif

1.3,Kconfig.projbuild 修改如下
在这里插入图片描述

choice AUDIO_BOARD
    prompt "Ai-Thinker Audio board"
    default ESP_AI_THINKER_V2_2_BOARD
    help
        Select an audio board to use with the ESP-ADF
config AUDIO_BOARD_CUSTOM
    bool "Custom audio board"
config ESP_LYRAT_V4_3_BOARD
    bool "ESP32-Lyrat V4.3"
config ESP_LYRAT_V4_2_BOARD
    bool "ESP32-Lyrat V4.2"
config ESP_LYRATD_MSC_V2_1_BOARD
    bool "ESP32-LyraTD-MSC V2.1"
config ESP_LYRATD_MSC_V2_2_BOARD
    bool "ESP32-LyraTD-MSC V2.2"
config ESP_LYRAT_MINI_V1_1_BOARD
    bool "ESP32-Lyrat-Mini V1.1"
config ESP32_KORVO_DU1906_BOARD
    bool "ESP32_KORVO_DU1906"
config ESP32_S2_KALUGA_1_V1_2_BOARD
    bool "ESP32-S2-Kaluga-1 v1.2"
config ESP_AI_THINKER_V2_2_BOARD   
    bool "ESP32-AiThinker-audio V2.2"
endchoice

1.4 下载ai_thinker_audio_kit_v2_2提取码:kill

添加ai_thinker_audio_kit_v2_2文件夹到esp-adf\components\audio_board目录下,board.c是板子的初始化代码,board_def.h是对板子IO口的定义, board_pins_config.c是配置iis和iic的IO
引脚的代码。

2,添加音频驱动文件,修改esp-adf\components\audio_hal文件夹下的CMakeLists.txt和compoment.mk
在这里插入图片描述
2.1 CMakeLists.txt 修改后如下
在这里插入图片描述
2.2 compoment.mk 添加以下内容:

COMPONENT_ADD_INCLUDEDIRS += ./driver/ac101
COMPONENT_SRCDIRS += ./driver/ac101

2.3 在driver文件夹下新建ac101文件夹,并添加ac101.c和ac101.h驱动文件。ac101驱动下载
至此,移植完成!接下来就是测试了。老套路打开cmd,设置ADF_PATH,然后cd到测试项目,先执行idf.py menuconfig叫出配置菜单来切换A1S开发板。在Audio HAL选项中选择安信可的板子,然后save保存配置,最后idf.py build.(第一次编译大概5分钟把)
在这里插入图片描述
出现以下画面时就是编译通过:
在这里插入图片描述
最后进行烧录,插入开发板,查看开发板的端口号 例如我的是COM4,接着执行idf.py -p COM4 flash monitor烧录进开发板的同时开启了串口监视器,可以看到串口打印

四,使用asr语音识别例程

由于asr例程的app固件大于2M,所以需要修改项目分区表使app固件在flash有足够的内存空间,否则烧录后会出现以下错误:
在这里插入图片描述
步骤:
1,首先设置menuconfig->Serial Flash config,配置如下:
在这里插入图片描述
2,设置项目使用本地分区表:
menuconfig->Partition Table->,如下
在这里插入图片描述
3,修改项目根目录下的partitions.csv,如下
修改factory的size为2M或者更大的内存。

# Espressif ESP32 Partition Table
# Name,   Type, SubType, Offset,  Size
nvs,      data, nvs,     0x9000,  0x6000,
phy_init, data, phy,     0xf000,  0x1000,
factory,  app,  factory, 0x10000, 0x200000,

参考文章:
esp32-a1s 音频开发板移植最新 esp-adf 音频框架
ADF安装指南

### ESP32 Audio Development Framework (ADF) 使用指南 ESP-ADF 是乐鑫公司专门为 ESP32 系列芯片设计的音频开发框架,旨在简化基于该系列芯片的音频应用开发过程。它建立在 ESP-IDF 的基础上,并提供了丰富的 API 和示例代码,使开发者能够轻松实现各种音频功能[^1]。 #### 安装与配置 为了开始使用 ESP-ADF,首先需要安装 ESP-IDF 并设置好开发环境。完成后可以通过以下命令克隆 ADF 仓库到本地: ```bash git clone --recursive https://github.com/espressif/esp-adf.git ``` 如果遇到网络问题可以从国内镜像站点获取资源[^2]。接着按照官方文档中的指导完成必要的初始化工作,包括但不限于路径变量设定、工具链编译验证等环节。 #### 示例代码解析 以下是几个典型的 ADF 示例项目简介及其对应的目录位置: 1. **Music Player**: 展示如何构建一个基础版音乐播放器。 - 文件夹名:`examples/player/audio_player` ```c /* main.c */ #include "audio_element.h" void app_main() { i2s_stream_init(); // 初始化I2S接口 mp3_decoder_start(); // 启动MP3解码模块 } ``` 2. **Voice Recorder**: 教授录制声音文件的方法。 - 文件夹名:`examples/recorder/simple_recorder` 3. **Internet Radio**: 实现通过 HTTP 或 HLS 协议收听在线广播的功能。 - 文件夹名:`examples/cloud/internet_radio` 更多复杂案例可参阅源码库内的 `examples` 子目录下分类整理好的各类子项[^3]。 #### 关键特性概览 - 支持主流音频格式如 MP3, WAV 等; - 提供多种输入输出方式选择(麦克风阵列采集、蓝牙传输接收); - 内嵌常用通信协议栈支持(Wi-Fi连接管理、MQTT消息队列发布订阅机制); - 集成第三方服务对接能力(阿里云语音识别插件接入教程) 以上就是关于 ESP32 ADF 的基本介绍以及部分实用技巧分享。希望这些信息可以帮助您更好地理解和运用这一强大工具进行创新性的产品原型搭建---
评论 30
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值