天天看点

MediaCodec编码 音频pts设置

每一帧音频pcm录音,要进行mediacodec编码时,都需要为此pcm设置pts,在放入编码的input队列中。对于视频的pts来说,编码h264,一帧原始视频yuv420格式编码出的就是一帧h264,所以视频的pts可以直接取当前的时间戳就可以。但是对于音频来讲,一帧pcm数据,会编码出多帧的aac,mediacodec会根据送入编码器时设置的yuv420的pts,为每帧编码出的h264打一个pts。

音频的pts设置,就需要小心了。

首先,根据AudioRecord录音器配置的参数,根据采样率,声道数,采样位,和AudioRecord设置的输出buffer的大小,计算pts。

如下:

buffer_duration_us = 1000000 * ((double) mAudioBufferSize / mAudioChanelCount / 2 / mAudioSampleRate);
           

buffer_duration_us:每一帧pcm,需要叠加的时间间隔。

pts计算

pts = (long) (firstPresentationTimeUs + mCount * buffer_duration_us);
            if (getPTSUs() - pts > 300000) {
                firstPresentationTimeUs += getPTSUs() - pts;
                pts = (long) (firstPresentationTimeUs + mCount * buffer_duration_us);
            }
           

firstPresentationTimeUs:第一帧编码的pcm,对于当前系统的时间戳。

mCount:表示第几帧pcm数据。

这里以300毫秒为一个差值,如果当前设置的pts和系统的时间戳相差大于300毫秒的话,做一个校正。

然后设置pts给编码器。

mAudioEncoder.queueInputBuffer(inputIndex, 0, chunkPCM.length, pts, 0)
           

获取当前时间戳

protected long getPTSUs() {
        return System.nanoTime() / 1000L;
    }
           

继续阅读