Android MediaCodec:多个SurfaceViews支持多少个同步(视频)解码线程?

时间:2016-04-01 12:19:50

标签: android mediacodec

Grafika项目,文件DoubleDecodeActivity.java。我在3个SurfaceViews上使用MediaCodec API尝试了3个同步视频(h264)解码器。在使用Android 5.1 CRASHES将第4个解码器添加到第4个SurfaceView到Nexus 7时,那么可以使用或支持多少个同步解码器。

PS。在此次崩溃之后,MediaCodec不再工作了。需要重启设备才能使用MediaCodec。

以下是崩溃日志。在第{4}解码器线程的decoder.start()函数崩溃。

com.example.app.one V/DecodeActivity: Mime: video/avc
com.example.app.one I/OMXClient: Using client-side OMX mux.
com.example.app.one V/DecodeActivity: Mime: video/avc
com.example.app.one I/OMXClient: Using client-side OMX mux.
com.example.app.one V/DecodeActivity: Mime: video/avc
com.example.app.one E/ACodec: [OMX.qcom.video.decoder.avc] storeMetaDataInBuffers failed w/ err -2147483648
com.example.app.one E/ACodec: [OMX.qcom.video.decoder.avc] storeMetaDataInBuffers failed w/ err -2147483648
com.example.app.one W/ACodec: do not know color format 0x7fa30c03 = 2141391875
com.example.app.one W/ACodec: do not know color format 0x7fa30c03 = 2141391875
com.example.app.one I/OMXClient: Using client-side OMX mux.
com.example.app.one V/DecodeActivity: Mime: video/avc
com.example.app.one I/OMXClient: Using client-side OMX mux.
com.example.app.one E/ACodec: [OMX.qcom.video.decoder.avc] storeMetaDataInBuffers failed w/ err -2147483648
com.example.app.one E/ACodec: [OMX.qcom.video.decoder.avc] storeMetaDataInBuffers failed w/ err -2147483648
com.example.app.one W/ACodec: do not know color format 0x7fa30c03 = 2141391875
com.example.app.one W/ACodec: do not know color format 0x7fa30c03 = 2141391875
com.example.app.one E/ACodec: registering GraphicBuffer 9 with OMX IL component failed: -2147483648
com.example.app.one V/PlayerFromFileThread: inputBuffer not available.
com.example.app.one E/ACodec: Failed to allocate buffers after transitioning to IDLE state (error 0x80000000)
com.example.app.one E/ACodec: signalError(omxError 0x80001001, internalError -2147483648)
com.example.app.one V/PlayerFromFileThread: inputBuffer not available.
com.example.app.one E/MediaCodec: Codec reported err 0x80001001, actionCode 0, while in state 5
? E/ACodec: registering GraphicBuffer 4 with OMX IL component failed: -2147483648
? E/AndroidRuntime: FATAL EXCEPTION: Thread-485
                                                   Process: com.example.app.one, PID: 17143
                                                   android.media.MediaCodec$CodecException: start failed
                                                       at android.media.MediaCodec.native_start(Native Method)
                                                       at android.media.MediaCodec.start(MediaCodec.java:612)
                                                       at com.example.app.one.MainActivity$PlayerFromFileThread.run(MainActivity.java:1921)
? E/ACodec: Failed to allocate buffers after transitioning to IDLE state (error 0x80000000)
? E/ACodec: signalError(omxError 0x80001001, internalError -2147483648)
? E/MediaCodec: Codec reported err 0x80001001, actionCode 0, while in state 5

1 个答案:

答案 0 :(得分:1)

这个定义不明确。

在API 23中添加了MediaCodecInfo getMaxSupportedInstances()方法,该方法大胆宣称:“这是上限的提示。”

严格定义此值的问题在于硬件实例的数量可能受带宽要求的限制,而不是固定值。因此,您可以解码两个720p流,但只能解码一个1080p流。

在许多设备上,如果硬件无法支持您的请求,OMX将切换到软件解码器,例如其中一个较旧的Nexus设备可让您使用硬件编解码器解码两个流,然后开始分发软件编解码器实例。

getMaxSupportedInstances()电话试图提供更多信息,但据我所知,仍有一定数量的每台设备试验和错误需要确定设备的确切用途。