Rob*_*ade 5 android android-mediacodec
我正在处理实时流,MediaCodec并且有一个场景,其中MediaFormat流中发生变化(即:正在解码的视频的分辨率发生变化)。鉴于我将解码器附加到 aSurface以在检测到传入流的分辨率变化后立即渲染它,我会在向其提供新的分辨率缓冲区之前重新创建解码器(为其提供正确的 new 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)
Run Code Online (Sandbox Code Playgroud)
当获取它时,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...
Run Code Online (Sandbox Code Playgroud)
看起来像是打电话stop()并release()重新初始化我所拥有的所有引用getInputBuffers()并getOutputBuffers()完成了任务。至少我不再收到消息/异常。现在我只需要找出Surface参考部分,因为调整大小的流(当分辨率发生变化时)似乎仍然适合原始表面尺寸,而不是调整表面以适应新的分辨率。
| 归档时间: |
|
| 查看次数: |
4647 次 |
| 最近记录: |