Welcome to mirror list, hosted at ThFree Co, Russian Federation.

github.com/FFmpeg/FFmpeg.git - Unnamed repository; edit this file 'description' to name the repository.
summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorMarton Balint <cus@passwd.hu>2013-03-02 23:21:52 +0400
committerMarton Balint <cus@passwd.hu>2013-03-17 06:31:37 +0400
commit9eafdd518cc804d7be5cabe0af821d878d8e2048 (patch)
tree71a0dc6a6de006f8f95dd1e456489c2de6eae7ed /ffplay.c
parent1822519d2a139ed5ea68aa2d5832093ff1b05ec6 (diff)
ffplay: use frame->pts if available for setting the audio clock
Signed-off-by: Marton Balint <cus@passwd.hu>
Diffstat (limited to 'ffplay.c')
-rw-r--r--ffplay.c19
1 files changed, 11 insertions, 8 deletions
diff --git a/ffplay.c b/ffplay.c
index bd417207cb..34ebe476ae 100644
--- a/ffplay.c
+++ b/ffplay.c
@@ -2091,6 +2091,12 @@ static int audio_decode_frame(VideoState *is)
flush_complete = 1;
continue;
}
+
+ if (is->frame->pts == AV_NOPTS_VALUE && pkt_temp->pts != AV_NOPTS_VALUE)
+ is->frame->pts = av_rescale_q(pkt_temp->pts, is->audio_st->time_base, dec->time_base);
+ if (pkt_temp->pts != AV_NOPTS_VALUE)
+ pkt_temp->pts += (double) is->frame->nb_samples / is->frame->sample_rate / av_q2d(is->audio_st->time_base);
+
data_size = av_samples_get_buffer_size(NULL, av_frame_get_channels(is->frame),
is->frame->nb_samples,
is->frame->format, 1);
@@ -2154,8 +2160,11 @@ static int audio_decode_frame(VideoState *is)
}
audio_clock0 = is->audio_clock;
- is->audio_clock += (double)data_size /
- (av_frame_get_channels(is->frame) * is->frame->sample_rate * av_get_bytes_per_sample(is->frame->format));
+ /* update the audio clock with the pts */
+ if (is->frame->pts != AV_NOPTS_VALUE) {
+ is->audio_clock = is->frame->pts * av_q2d(dec->time_base) + (double) is->frame->nb_samples / is->frame->sample_rate;
+ is->audio_clock_serial = is->audio_pkt_temp_serial;
+ }
#ifdef DEBUG
{
static double last_clock;
@@ -2190,12 +2199,6 @@ static int audio_decode_frame(VideoState *is)
}
*pkt_temp = *pkt;
-
- /* if update the audio clock with the pts */
- if (pkt->pts != AV_NOPTS_VALUE) {
- is->audio_clock = av_q2d(is->audio_st->time_base)*pkt->pts;
- is->audio_clock_serial = is->audio_pkt_temp_serial;
- }
}
}