Я использую приведенный выше код для кодирования/декодирования/мультиплексирования, чтобы сделать видео с более низким разрешением и битрейтом. Он отлично работает на всех разрешениях, включая видео 4k на nexus5, LG g3, one plus.
Но устройства Samsung ведут себя неадекватно.
Если я беру видео 4k (3840x2160) в качестве входных данных и хочу снизить его разрешение до 1920x1080, я получаю исключение.
Если я беру видео 4k (3840x2160) в качестве входных данных и хочу снизить его разрешение до 1280x720, я все равно получаю исключение.
Он отлично работает, если я установил целевое разрешение 640x360.
Я думаю, что это может быть связано с проблемами кодека на устройствах Samsung.
Ниже приведен фрагмент кода
MediaCodec encoder = MediaCodec.createByCodecName(codecInfo.getName());
encoder.configure(format, null, null, MediaCodec.CONFIGURE_FLAG_ENCODE);
surfaceReference.set(encoder.createInputSurface());
encoder.start();
MediaCodec decoder = MediaCodec.createDecoderByType(getMimeTypeFor(inputFormat));
decoder.configure(inputFormat, surface, null, 0);
decoder.start();
Следующий оператор вызывает исключение
decoder.configure(inputFormat, surface, null, 0);
Ниже приведена трассировка стека
I/ACodec: [OMX.Exynos.AVC.Encoder] Now Executing
03-15 14:35:23.801 25357-26008/com.test I/ACodec: [] Now uninitialized
03-15 14:35:23.801 25357-26036/com.test I/OMXClient: Using client-side OMX mux.
03-15 14:35:23.811 25357-26036/com.test I/ACodec: can't find wfdsink-exynos-enable
03-15 14:35:23.811 25357-26036/com.test E/ACodec: configureCodec multi window instance fail appPid : 25357
03-15 14:35:23.811 25357-26036/com.test E/ACodec: [OMX.Exynos.avc.dec] configureCodec returning error -1021
03-15 14:35:23.811 25357-26036/com.test E/ACodec: signalError(omxError 0x80001001, internalError -1021)
03-15 14:35:23.811 25357-26035/com.test E/MediaCodec: Codec reported err 0xfffffc03, actionCode 0, while in state 3
03-15 14:35:23.811 25357-26008/com.test E/MediaCodec: configure failed with err 0xfffffc03, resetting...
03-15 14:35:23.811 25357-26036/com.test I/ACodec: [OMX.Exynos.avc.dec] Now uninitialized
03-15 14:35:23.811 25357-26008/com.test I/ACodec: [] Now uninitialized
03-15 14:35:23.811 25357-26036/com.test I/OMXClient: Using client-side OMX mux.