我正在通过以下方式处理直播MediaCodec
并有一个场景MediaFormat
中流发生变化(即:正在解码的视频的分辨率发生变化)。鉴于我将解码器附加到Surface
为了在检测到传入流的分辨率变化后立即渲染它,我在向其提供新的分辨率缓冲区之前重新创建解码器(为其提供适当的新分辨率)MediaFormat
).
我遇到了一些奇怪的错误,这些错误没有给我太多关于可能出现问题的信息,即在调用时MediaCodec.configure
与新格式相同Surface
:
android.media.MediaCodec$CodecException: Error 0xffffffea
at android.media.MediaCodec.native_configure(Native Method)
at android.media.MediaCodec.configure(MediaCodec.java:577)
获取时哪个CodecException.getDiagnosticInfo
它没有显示任何我可以真正用来理解失败原因的信息:android.media.MediaCodec.error_neg_22
我还在日志中注意到以下内容并找到了一些相关信息,并且想知道是否需要对以下内容做一些事情Surface
本身(就像将其从解码器的旧实例中分离出来并将其交给新解码器一样):
07-09 15:00:17.217 E/BufferQueueProducer( 139): [SurfaceView] connect(P): already connected (cur=3 req=3)
07-09 15:00:17.217 E/MediaCodec( 5388): native_window_api_connect returned an error: Invalid argument (-22)
07-09 15:00:17.218 E/MediaCodec( 5388): configure failed with err 0xffffffea, resetting...
看起来像打电话stop()
and release()
以及重新初始化我对getInputBuffers()
and getOutputBuffers()
成功了。至少我不再收到消息/异常。现在我只需要弄清楚Surface
参考部分,因为看起来调整大小的流(当分辨率改变时)仍然适合原始表面尺寸,而不是调整表面以适应新的分辨率。
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)