我想将音频文件解码为原始PCM数据,以将其流式传输到本地网络中的播放设备.我使用了API级别16引入的新的 MediaExtractor和 MediaCodec类.该器件要求PCM数据为44,100 kHz,有2个通道和16位样本大小.只要输入文件大致符合这些要求,这就可以正常工作.但是,无论何时我正在解码使用的文件 – 例如 – 32,000 kHz的采样率并且可能只有一个通道,那么我无法从MediaCodec类获得所需的输出.

因为我似乎无法指定MediaCodec类的输出格式.所以我决定实例化另一个MediaCodec对象,将原始数据重新编码为我想要的格式.根据supported media formats Android列表支持自Android 4.1以来编码到PCM / Wave.但是我无法创建编码为PCM / Wave的MediaCodec对象.我尝试将各种MIME类型传递给MediaCodec.createEncoderByType(type);但我总是以IOException失败:

java.io.IOException: Failed to allocate component instance
at android.media.MediaCodec.native_setup(Native Method)
at android.media.MediaCodec.<init>(MediaCodec.java:210)
at android.media.MediaCodec.createEncoderByType(MediaCodec.java:194)
[..]

你有没有人能够成功创建一个编码为PCM / Wave的MediaCodec实例,并能为我提供一个有效的例子吗?

解决方法

根据我们在评论中的对话,这个答案涉及使用OpenSL将音频数据解码到PCM.不幸的是,我无法使用MediaCodec类提供类似的答案.

首先,设置一个Android NDK项目(使用Eclipse:右键单击项目,Android工具 – >添加本机支持…).然后,在创建的Android.mk文件中,至少需要链接到OpenSL库:

LOCAL_LDLIBS += -lOpenSLES

如果您还不熟悉NDK项目,那么旧的互联网上会有很多教程,例如here和here.

一旦你有一个NDK项目工作,总的目标是设置一个音频播放器作为PCM的解码器.实际上有一个example in the NDK samples正是如此.它比你制作一个最小功能的工具要复杂一点,但它应该让你前进.有一个非常容易理解的描述正在发生的事情at this link(搜索“解码音频到PCM”).我在评论中为您提供了相关OpenSL spec的链接,但又有了.指定数据接收器时需要使用的SLDataFormat_PCM结构如下所示:

SLDataFormat_PCM pcm = {
    SL_DATAFORMAT_PCM,2,// numChannels
    SL_SAMPLINGRATE_44_1,// samplesPerSec
    SL_PCMSAMPLEFORMAT_FIXED_16,// bitsPerSample
    SL_PCMSAMPLEFORMAT_FIXED_16,// containerSize
    SL_SPEAKER_FRONT_LEFT |
        SL_SPEAKER_FRONT_RIGHT,// channelMask
    SL_BYTEORDER_LITTLEENDIAN     // endianness
};

按照示例和描述性指南,您将使用Android简单缓冲区队列数据定位器和上述数据格式定义SLDataSink.然后,播放器应为您提供一系列包含正确格式数据的缓冲区.然后,您可以将该数据传递回Java,或者(更好地)从本机代码传输数据.

android – 解码音频文件并重新编码为所需的PCM格式:44,100 kHz,2个通道,16位的更多相关文章

  1. HTML5录音实践总结(Preact)

    这篇文章主要介绍了HTML5录音实践总结,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下

  2. ios – 我可以使用AVCaptureSession将AAC流编码到内存吗?

    解决方法我最后向Apple寻求建议.似乎AVCaptureSession抓住了AAC硬件编码器,但只允许您使用它直接写入文件.您可以使用软件编码器,但您必须专门询问它而不是使用AudioConverterNew:同当然,软件编码器会占用cpu资源,但会完成工作.

  3. ios – AVAssetReaderOutput copyNextSampleBuffer在设备上编码带有音频的视频时挂起

    在这个问题VideoEncodingusingAVAssetWriter–CRASHES中实现编码视频(带音频)的解决方案之后,我发现代码在iPhone模拟器中正常工作.不幸的是,某些视频在实际的iPhone5(和其他设备)上运行时无法对其音频进行编码.例如,从WWDC2011示例代码RosyWriter(https://developer.apple.com/library/IOS/sample

  4. Swift iOS实现把PCM语音转成MP3格式

    最近折腾了swift的语音录制识别和转码,这块还是比较坑的,由于语音识别的准确度实测大概也就80%左右,所以还是需要上传录音文件啊。首先是用讯飞语音SDK实现语音录制和识别,第一个坑是讯飞SDK只录制了PCM格式的文件,这个文件是原始格式,默认比较大,另外播放器支持也不好,因此需要先把它转成mp3,本来考虑使用系统的AudioConverter转aac格式,不过aac好像不能在浏览器上播放。

  5. 如何直接从Android Surface访问EGL图像以用于MediaCodec视频解码器?

    )而无需进行格式转换,但目前还没有类似的机制.我不知道比你描述的更好的方法.更新:我的办公室伙伴提出了一个建议:使用着色器将缓冲区渲染为两个纹理,一个用于Y,另一个用于CbCr.这样可以保持GLES中的所有操作,而不会扩展到完整的RGB.在内部,它会将MediaCodec输出转换为RGB并通过它进行两次研磨,但这可能比将其复制到用户空间并在cpu上自行完成更便宜.

  6. MediaCodec如何在Android框架内找到编解码器?

    我试图了解MediaCodec如何用于硬件解码.我在android内部的知识非常有限.这是我的发现:有一个xml文件代表android系统中的编解码器细节.这意味着,如果我们使用MediaCodec从JavaApplication创建编解码器应该在xml文件的帮助下找出相应的编码器.我在做什么?

  7. android – 解码音频文件并重新编码为所需的PCM格式:44,100 kHz,2个通道,16位

    解决方法根据我们在评论中的对话,这个答案涉及使用OpenSL将音频数据解码到PCM.不幸的是,我无法使用MediaCodec类提供类似的答案.首先,设置一个AndroidNDK项目(使用Eclipse:右键单击项目,Android工具–>添加本机支持…

  8. android – 使用MediaCodec编码之前为Grafika的“连续捕获”活动裁剪视频

    解决方法看看“相机纹理”活动.请注意,它允许您以各种方式操作图像,特别是“缩放”.“缩放”是通过修改纹理坐标来完成的.ScaledDrawable2D班这样做;rectScale()调用改变了“缩放”,而不是缩放矩形本身.纹理坐标的范围从0.0到1.0(含),getTexCoordArray()方法修改它们以跨越纹理的子集.要剪切帧,您需要按比例修改纹理坐标.例如,如果输入视频是纵向720×1280,并且您想要720×720,则可以更改此坐标:对此:然后在正方形而不是矩形上渲染它.

  9. android – 调用MediaCodec.configure()时出现非法状态异常

    奇怪的是它只发生在某些设备上.欢迎大家提出意见!

  10. 如何将H.264 NAL设备提供给Android MediaCodec进行解码?

    我应该在发送NAL单元之前剥离0x000x000x01序列吗?我是否需要忽略/删除某些NAL单元类型?

随机推荐

  1. bluetooth-lowenergy – Altbeacon库无法在Android 5.0上运行

    昨天我在Nexus4上获得了Android5.0的更新,并且altbeacon库停止了检测信标.似乎在监视和测距时,didEnterRegion和didRangeBeaconsInRegion都没有被调用.即使RadiusNetworks的Locate应用程序现在表现不同,一旦检测到信标的值,它们就不再得到更新,并且通常看起来好像信标超出了范围.我注意到的一点是,现在在logcat中出现以下行“B

  2. android – react-native动态更改响应者

    我正在使用react-native进行Android开发.我有一个视图,如果用户长按,我想显示一个可以拖动的动画视图.我可以使用PanResponder实现这一点,它工作正常.但我想要做的是当用户长按时,用户应该能够继续相同的触摸/按下并拖动新显示的Animated.View.如果您熟悉Google云端硬盘应用,则它具有类似的功能.当用户长按列表中的任何项目时,它会显示可拖动的项目.用户可以直接拖

  3. android – 是否有可能通过使用与最初使用的证书不同的证书对其进行签名来发布更新的应用程序

    是否可以通过使用与最初使用的证书不同的证书进行签名来发布Android应用程序的更新?我知道当我们尝试将这样的构建上传到市场时,它通常会给出错误消息.但有没有任何出路,比如将其标记为主要版本,指定市场中的某个地方?解决方法不,你不能这样做.证书是一种工具,可确保您是首次上传应用程序的人.所以总是备份密钥库!

  4. 如何检测Android中是否存在麦克风?

    ..所以我想在让用户访问语音输入功能之前检测麦克风是否存在.如何检测设备上是否有麦克风.谢谢.解决方法AndroidAPI参考:hasSystemFeature

  5. Android – 调用GONE然后VISIBLE使视图显示在错误的位置

    我有两个视图,A和B,视图A在视图B上方.当我以编程方式将视图A设置为GONE时,它将消失,并且它正下方的视图将转到视图A的位置.但是,当我再次将相同的视图设置为VISIBLE时,它会在视图B上显示.我不希望这样.我希望视图B回到原来的位置,这是我认为会发生的事情.我怎样才能做到这一点?编辑–代码}这里是XML:解决方法您可以尝试将两个视图放在RelativeLayout中并相对于彼此设置它们的位置.

  6. android – 获得一首歌的流派

    我如何阅读与歌曲相关的流派?我可以读这首歌,但是如何抓住这首歌的流派,它存放在哪里?解决方法检查此代码:

  7. android – 使用textShadow折叠工具栏

    我有一个折叠工具栏的问题,在展开状态我想在文本下面有一个模糊的阴影,我使用这段代码:用:我可以更改textColor,它可以工作,但阴影不起作用.我为阴影尝试了很多不同的值.是否可以为折叠文本投射阴影?

  8. android – 重用arm共享库

    我已经建立了armarm共享库.我有兴趣重用一个函数.我想调用该函数并获得返回值.有可能做这样的事吗?我没有任何头文件.我试过这个Android.mk,我把libtest.so放在/jni和/libs/armeabi,/lib/armeabi中.此时我的cpp文件编译,但现在是什么?我从objdump知道它的名字编辑:我试图用这个android.mk从hello-jni示例中添加prebuild库:它工作,但libtest.so相同的代码显示以下错误(启动时)libtest.so存在于libhello-j

  9. android – 为NumberPicker捕获键盘’Done’

    我有一个AlertDialog只有一些文本,一个NumberPicker,一个OK和一个取消.(我知道,这个对话框还没有做它应该保留暂停和恢复状态的事情.)我想在软键盘或其他IME上执行“完成”操作来关闭对话框,就像按下了“OK”一样,因为只有一个小部件可以编辑.看起来处理IME“Done”的最佳方法通常是在TextView上使用setonEditorActionListener.但我没有任何Te

  10. android – 想要在调用WebChromeClient#onCreateWindow时知道目标URL

    当我点击一个带有target=“_blank”属性的超链接时,会调用WebChromeClient#onCreateWindow,但我找不到新的窗口将打开的新方法?主页url是我唯一能知道的东西?我想根据目标网址更改应用行为.任何帮助表示赞赏,谢谢!

返回
顶部