每一帧音频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;
}