首页 > 解决方案 > 对于某些特定视频的音频,我使用 mediaExtractor 和 mediaFormat 获得一半的通道数和一半的采样率

问题描述

对于某些特定视频的音频,我使用 android mediaExtractor 和 mediaFormats 获得了一半的通道数和一半的采样率(例如:通道数为 2,采样率为 44100,但我得到的通道数为 1,采样率为 22050)。对于其他视频,它工作正常。我注意到的一件事是,对于“aac profile = 29”,它会导致问题。

我正在使用的代码

   MediaExtractor extractor = new MediaExtractor();



        try {
            extractor.setDataSource( path);

            int trackIndex = MetadataUtils.getTrackIndex(extractor, "audio/");
            if (trackIndex != -1) {
                MediaFormat format = extractor.getTrackFormat(trackIndex);

                audioMetadata.mAudioTrackIndex = trackIndex;
                audioMetadata.mAudioTrackFormat = format;

                if (format != null) {

                    if (format.containsKey(MediaFormat.KEY_MIME)) {
                        audioMetadata.mAudioMimeType = format.getString(MediaFormat.KEY_MIME);
                        MediaFormat.KEY_AAC_PROFILE
                    }

                    if (format.containsKey(MediaFormat.KEY_CHANNEL_COUNT)) {
                        audioMetadata.mNoInputChannel = format.getInteger(MediaFormat.KEY_CHANNEL_COUNT);
                    }
                    
                    if (format.containsKey(MediaFormat.KEY_SAMPLE_RATE)) {
                        audioMetadata.mInputSampleRateHz = format.getInteger(MediaFormat.KEY_SAMPLE_RATE);
                    }

                    if (format.containsKey(MediaFormat.KEY_DURATION)) {
                        audioMetadata.mAudioDurationUs = format.getLong(MediaFormat.KEY_DURATION);
                    }
                }
            }

        } catch (IOException e) {
            e.printStackTrace();
        } finally {
            extractor.release();
        }

我怎样才能解决这个问题 ?

标签: androidaudioandroid-mediacodecmediaextractor

解决方案


当 KEY_AAC_PROFILE 为 29 时,表示 AACObjectHE_PS 或 HE AAC v2。当 KEY_AAC_PROFILE 为 5 时,表示 AACObjectHE 或 HE AAC

HE AAC中使用了SBR(Spectral Band Replication),所以实际采样率会翻倍。在 HE AAC v2 中,同时使用了 SBR(Spectral Band Replication)和 PS(Parametric Stereo),因此实际采样率和通道数将增加一倍。

有关更多信息,请参阅以下链接

https://tech.ebu.ch/docs/techreview/trev_305-moser.pdf https://datatracker.ietf.org/doc/html/rfc6416

另一种解决方案:为此,您必须使用 mediaCodec 解码音频文件,在onOutputFormatChanged(codec: MediaCodec, format: MediaFormat)回调中,您将有准确的 channelCount 和 sampleRate格式


推荐阅读