
我已经看过android原生音频样本了,这本书开始使用android ndk,这让我开始使用opensl,但是他们并没有真正帮助我理解录音.
1)首先,要立即回放录制的音频,我是否能够从播放音频的线程中读取缓冲区,同时录制线程正在写入缓冲区?我知道有人可能会对这个想法发疯,因为同时通过两个不同的线程访问内存中的某个对象的想法可能会导致问题,但是如果记录线程确保始终在内存之前写入内存播放音频线程,那可能是对的吗?
2)或者为了实时回放,我将使用具有两个或三个非常小的缓冲区的缓冲区队列,以及每次填充时调用的回调,然后在下一个缓冲区被记录填充时播放该缓冲区音频线程?但我正在阅读,有人说回调并不总是被调用(我发现的最有用的链接是:https://groups.google.com/forum/#!msg/android-ndk/hLSygQrmcPI/qtwB76JNa_EJ).此外,这意味着录制的音频和播放的音频之间的时间差将是缓冲区的大小加上回调使记录对象知道使用下一个缓冲区开始记录所花费的时间.我认为录音机停止录音和再开始录音之间会有一个间隙.
3)android记录缓冲区队列也是我理解的问题.我是否必须在android中使用缓冲队列来录制音频?或者是否可以在不使用缓冲队列的情况下直接记录到缓冲区?我遇到了这个问题,因为SLAndroidSimpleBufferQueueItf的清晰方法实际上似乎不起作用.显然它是一个错误.我似乎无法在已填充数据后记录缓冲区.由于clear方法似乎不起作用,我如何告诉记录器队列中的哪个缓冲区要记录?
我知道这有点问题,我没有说过我尝试过的所有内容,但我希望有人对此有一些经验,并且可以为我和其他有问题的人播放录音使用opensl实时音频.
http://audioprograming.wordpress.com/
Android中的OpenSL ES仍然不能完全支持“低延迟”,因为仍有轻微的延迟,但它仍然能够很好地工作,它听起来更像是一个轻微的回声
转载注明原文:使用opensl es和android ndk实时播放音频 - 乐贴网