我正在尝试为 iPhone 编写波形可视化工具,但在 ExtAudioFileRead 方面遇到了一个有趣的问题。
我正在读取 VBR MP3 文件。我的客户端格式是 44.1kHz LPCM,单声道。
我将寻找一个我想要可视化的位置,并以 1024 帧的形式阅读。我看到的是,在 70% 或 80% 的情况下,我会在前 512 帧左右的帧中返回零。读取报告它已成功读取所有请求的帧。
此外,我已确认我正在寻找正确的位置。如果我将读取结果放入音频队列中,它显然是文件中的正确位置。
那么什么给出了呢?对于为什么会出现这种情况有什么想法吗?我在文档中找不到与此问题相关的任何内容。
最佳答案
我设法通过查找请求帧位置之前 1024 帧的位置,读取 1024 + requestedLength
帧,然后拉出最后一个 requestedLength
帧来解决此问题缓冲区。
我不确定为什么这个解决方案有效,但我有一个理论(以防有人读到这篇文章)
在压缩格式中,音频文件被分成数据包。数据包中间的帧需要对任何先前的帧(来自同一数据包)进行解码才能被理解。
猜测
也许当您使用ExtAudioFileSeek
查找中间数据包时,不会发生此解码,并且将返回零,直到您到达下一个数据包边界。
我的解决方案可能有效,因为我回溯得足够远,可以从同一数据包中读取我想要的帧之前的所有帧,因此确实会进行解码。
关于ios - ExtAudioFileSeek 后跟 ExtAudioFileRead 返回许多连续的 0 样本(不可能),我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/9977971/