mirror of
https://github.com/samsonjs/media.git
synced 2026-03-30 10:15:48 +00:00
Move raw audio decoder channel count workaround to DefaultCodec.
PiperOrigin-RevId: 630071329
This commit is contained in:
parent
7cf2fd9486
commit
cb846f0b0d
2 changed files with 6 additions and 8 deletions
|
|
@ -361,6 +361,11 @@ public final class DefaultCodec implements Codec {
|
|||
if (outputBufferIndex == MediaCodec.INFO_OUTPUT_FORMAT_CHANGED) {
|
||||
outputFormat =
|
||||
convertToFormat(mediaCodec.getOutputFormat(), isDecoder, configurationFormat.metadata);
|
||||
// The raw audio decoder incorrectly sets the channel count for output format to stereo.
|
||||
if (isDecoder && Objects.equals(configurationFormat.sampleMimeType, MimeTypes.AUDIO_RAW)) {
|
||||
outputFormat =
|
||||
outputFormat.buildUpon().setChannelCount(configurationFormat.channelCount).build();
|
||||
}
|
||||
}
|
||||
return false;
|
||||
}
|
||||
|
|
|
|||
|
|
@ -219,6 +219,7 @@ import org.checkerframework.checker.nullness.qual.RequiresNonNull;
|
|||
}
|
||||
inputFormat = overrideInputFormat(checkNotNull(formatHolder.format));
|
||||
onInputFormatRead(inputFormat);
|
||||
// TODO: b/332708880 - Bypass MediaCodec for raw audio input.
|
||||
shouldInitDecoder =
|
||||
assetLoaderListener.onTrackAdded(
|
||||
inputFormat, SUPPORTED_OUTPUT_TYPE_DECODED | SUPPORTED_OUTPUT_TYPE_ENCODED);
|
||||
|
|
@ -262,14 +263,6 @@ import org.checkerframework.checker.nullness.qual.RequiresNonNull;
|
|||
if (decoderOutputFormat == null) {
|
||||
return false;
|
||||
}
|
||||
|
||||
// TODO: b/332708880 - The raw decoder caps number of audio channels to stereo. Remove this
|
||||
// workaround and bypass MediaCodec for raw audio instead.
|
||||
if (checkNotNull(inputFormat.sampleMimeType).equals(MimeTypes.AUDIO_RAW)) {
|
||||
decoderOutputFormat =
|
||||
decoderOutputFormat.buildUpon().setChannelCount(inputFormat.channelCount).build();
|
||||
}
|
||||
|
||||
outputFormat = overrideOutputFormat(decoderOutputFormat);
|
||||
} else {
|
||||
// TODO(b/278259383): Move surface creation out of video sampleConsumer. Init decoder and
|
||||
|
|
|
|||
Loading…
Reference in a new issue