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

ESP32 005 MicroPython I2S 实现音频传输与播放

  • I²S(Inter-IC Sound) 是一种专用于数字音频传输的串行总线标准,广泛用于微控制器(如 ESP32)与音频 DAC(如 PCM5102)之间传输音频数据。

I2S 主要信号线

  • ESP32 I2S 与 PCM5102 示例连接 (PCM5102、PCM510xA I2S音频协议 DAC芯片 & PCM5102模块与接线说明)
信号线名称全称/别名功能描述
BCLKBit Clock / SCK每一位数据的时钟,用于数据同步
LRCLKLeft-Right Clock / WS左右声道选择,High 表示右声道,Low 表示左声道
DATASerial Data / SD / DIN音频的实际数据流
MCLKMaster Clock (可选)主系统时钟(部分 DAC 可不接,PCM5102 内置 PLL 可省略)

在这里插入图片描述

上传 wav到 SPIFFS(Thonny)

  1. 打开 视图 > 文件
  2. 拖拽 ***.wav 到 MicroPython 设备(根目录)
  3. 等待上传成功

在这里插入图片描述

python函数接口说明

# https://github.com/micropython/micropython/blob/master/ports/esp32/machine_i2s.cfrom machine import I2S, Pinaudio = I2S(0,sck=Pin(9),ws=Pin(10),sd=Pin(11),mode=I2S.TX,bits=16,format=I2S.STEREO,rate=16000,ibuf=40000
)
函数/参数说明
I2S(id, **kwargs)创建 I2S 对象。id 一般为 01,参数通过关键字传入。
idI2S 外设编号。ESP32 通常支持 01(部分板子支持 2)。
sck / bckBit Clock(位时钟)引脚,接到 DAC 的 BCK 引脚。
ws / lrckWord Select / LRCK 引脚,接到 DAC 的 LCK 引脚。
sdSerial Data,引脚接到 DAC 的 DIN
modeI2S.TX(发送)或 I2S.RX(接收)。
bits采样精度,常用值为 162432。需与 WAV 文件位深一致。
format通道格式:I2S.MONOI2S.STEREO
rate采样率(Hz),例如 16000、44100、48000 等。需与音频文件一致。
ibuf内部缓冲区大小(字节),越大越平稳但占用 RAM。

CODE实现

from machine import Pin, I2S
import ustruct
import time# ======== 配置 I2S ========
SCK_PIN = 9   # Bit Clock (BCK)
WS_PIN  = 10   # Word Select (LRCK)
SD_PIN  = 11   # Data (DIN)audio_out = I2S(0,                         # I2S peripheral IDsck=Pin(SCK_PIN),ws=Pin(WS_PIN),sd=Pin(SD_PIN),mode=I2S.TX,bits=16,format=I2S.STEREO,         # I2S.STEREO 或 I2S.MONO,取决于 WAV 文件rate=16000,                # 与音频采样率一致ibuf=40000
)
# ===========================# # ======== 解析 WAV 头部并跳过 ========
# def skip_wav_header(f):
#     # 跳过 WAV 文件头部,找到数据段
#     while True:
#         chunk_id = f.read(4)
#         if chunk_id == b'data':
#             data_size = ustruct.unpack('<I', f.read(4))[0]
#             return data_size
#         else:
#             f.read(ustruct.unpack('<I', f.read(4))[0])import ustructdef skip_wav_header(f):# Read RIFF headerif f.read(4) != b'RIFF':raise ValueError('Invalid WAV file: missing RIFF')f.read(4)  # Chunk sizeif f.read(4) != b'WAVE':raise ValueError('Invalid WAV file: missing WAVE')# Search for 'data' chunkwhile True:chunk_id = f.read(4)if len(chunk_id) < 4:raise ValueError("Reached end of file before finding 'data' chunk")chunk_size_bytes = f.read(4)if len(chunk_size_bytes) < 4:raise ValueError("Corrupted WAV file")chunk_size = ustruct.unpack('<I', chunk_size_bytes)[0]if chunk_id == b'data':return chunk_size  # return data sizeelse:# skip over this chunkf.read(chunk_size)# ======== 播放 WAV 文件 ========
wav_file = "/music-16k-16bits-mono.wav"with open(wav_file, "rb") as f:
#     header = f.read(44)  # 假设标准 44 字节 WAV header
#     data_size = skip_wav_header(f)
#     print("Data size:", data_size)data_size = skip_wav_header(f)  # 不要再提前读 44 字节print("Data size:", data_size)# 循环读取并播放音频数据while True:wav_data = f.read(1024)if not wav_data:breakaudio_out.write(wav_data)# ======== 释放 I2S ========
audio_out.deinit()
http://www.dtcms.com/a/250826.html

相关文章:

  • 性能优化 - 案例篇:11种优化接口性能的通用方案
  • Bootstrap 5学习教程,从入门到精通, Bootstrap 5 列表组(List Group)语法知识点及案例(14)
  • AWS EC2 终极指南:如何选择预装 GPU 驱动和特定功能的最佳 AMI
  • AWS 解决方案深度剖析:Amazon QLDB — 构建可信赖、不可变的数据审计基石
  • 基于AWS无服务器架构的区块链API集成:零基础设施运维实践
  • 微软azure抢跑aws和谷歌云的区别
  • 线性代数(2)几何角度来理解线性方程组
  • Java面试题022:一文深入了解微服务网关Gateway
  • 【微服务】134:SpringCloud
  • SLB、Nginx、Gateway 与 ECS 的关系详解
  • Leetcode 刷题记录 15 —— 二分查找
  • Java可变参数方法的常见错误与最佳实践
  • 【锂电池剩余寿命预测】XGBoost锂电池剩余寿命预测(Pytorch完整源码和数据)
  • 深入理解Kafka Consumer:从理论到实战
  • SAP代理商——哲讯科技,助力企业数字化转型
  • 大数据实时风控引擎:Spark Streaming、Kafka、Flink与Doris的融合实践
  • 纺织行业SAP解决方案:无锡哲讯科技助力企业智能化升级
  • 国产替代新标杆|盟接之桥EDI软件让中国制造连接世界更安全、更简单、更有底气
  • 个人笔记-- TCL 替换
  • web3-区块链的技术安全/经济安全以及去杠杆螺旋(经济稳定)
  • Web3-代币ERC20/ERC721以及合约安全溢出和下溢的研究
  • go.work
  • (笔记)1.web3学习-区块链技术
  • web3方法详解
  • Oracle 逻辑结构与性能优化(上)
  • 【学习笔记】深入理解Java虚拟机学习笔记——第7章 虚拟机类加载机制
  • 基于 pysnmp 的实际业务场景应用案例:网络设备监控与配置系统
  • 【Linux手册】进程的状态:从创建到消亡的“生命百态”
  • 六月十五号Leetcode
  • React 实现砸金蛋游戏