aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorAndreas Unterweger <dustsigns@gmail.com>2015-01-27 09:03:08 +0100
committerAnton Khirnov <anton@khirnov.net>2015-01-27 09:03:08 +0100
commit3a70c0c95feacb3844d05eebd579fc8189a77eee (patch)
tree756339963719b018ad2b0e084b488aca49ca17c7
parentc9b19ac8928c6c9b7f25c3988177204f110d5e0e (diff)
downloadffmpeg-3a70c0c95feacb3844d05eebd579fc8189a77eee.tar.gz
examples/transcode_aac: generate proper PTS and set the muxer timebase
Signed-off-by: Anton Khirnov <anton@khirnov.net>
-rw-r--r--doc/examples/transcode_aac.c13
1 files changed, 13 insertions, 0 deletions
diff --git a/doc/examples/transcode_aac.c b/doc/examples/transcode_aac.c
index e0efe2d7b1..60698f719f 100644
--- a/doc/examples/transcode_aac.c
+++ b/doc/examples/transcode_aac.c
@@ -182,6 +182,10 @@ static int open_output_file(const char *filename,
/** Allow the use of the experimental AAC encoder */
(*output_codec_context)->strict_std_compliance = FF_COMPLIANCE_EXPERIMENTAL;
+ /** Set the sample rate for the container. */
+ stream->time_base.den = input_codec_context->sample_rate;
+ stream->time_base.num = 1;
+
/**
* Some container formats (like MP4) require global headers to be present
* Mark the encoder so that it behaves accordingly.
@@ -553,6 +557,9 @@ static int init_output_frame(AVFrame **frame,
return 0;
}
+/** Global timestamp for the audio frames */
+static int64_t pts = 0;
+
/** Encode one frame worth of audio to the output file. */
static int encode_audio_frame(AVFrame *frame,
AVFormatContext *output_format_context,
@@ -564,6 +571,12 @@ static int encode_audio_frame(AVFrame *frame,
int error;
init_packet(&output_packet);
+ /** Set a timestamp based on the sample rate for the container. */
+ if (frame) {
+ frame->pts = pts;
+ pts += frame->nb_samples;
+ }
+
/**
* Encode the audio frame and store it in the temporary packet.
* The output audio stream encoder is used to do this.