[FFmpeg-cvslog] r17639 - trunk/libavformat/ipmovie.c
reimar
subversion
Fri Feb 27 11:07:12 CET 2009
Author: reimar
Date: Fri Feb 27 11:07:12 2009
New Revision: 17639
Log:
Simplify ipmovie.c pts calculation by using an appropriate time_base.
Modified:
trunk/libavformat/ipmovie.c
Modified: trunk/libavformat/ipmovie.c
==============================================================================
--- trunk/libavformat/ipmovie.c Fri Feb 27 09:31:20 2009 (r17638)
+++ trunk/libavformat/ipmovie.c Fri Feb 27 11:07:12 2009 (r17639)
@@ -93,8 +93,7 @@ typedef struct IPMVEContext {
unsigned char *buf;
int buf_size;
- float fps;
- int frame_pts_inc;
+ uint64_t frame_pts_inc;
unsigned int video_width;
unsigned int video_height;
@@ -126,7 +125,6 @@ static int load_ipmovie_packet(IPMVECont
AVPacket *pkt) {
int chunk_type;
- int64_t audio_pts = 0;
if (s->audio_chunk_offset) {
@@ -139,16 +137,11 @@ static int load_ipmovie_packet(IPMVECont
url_fseek(pb, s->audio_chunk_offset, SEEK_SET);
s->audio_chunk_offset = 0;
- /* figure out the audio pts */
- audio_pts = 90000;
- audio_pts *= s->audio_frame_count;
- audio_pts /= s->audio_sample_rate;
-
if (s->audio_chunk_size != av_get_packet(pb, pkt, s->audio_chunk_size))
return CHUNK_EOF;
pkt->stream_index = s->audio_stream_index;
- pkt->pts = audio_pts;
+ pkt->pts = s->audio_frame_count;
/* audio frame maintenance */
if (s->audio_type != CODEC_ID_INTERPLAY_DPCM)
@@ -159,7 +152,7 @@ static int load_ipmovie_packet(IPMVECont
(s->audio_chunk_size - 6) / s->audio_channels;
debug_ipmovie("sending audio frame with pts %"PRId64" (%d audio frames)\n",
- audio_pts, s->audio_frame_count);
+ pkt->pts, s->audio_frame_count);
chunk_type = CHUNK_VIDEO;
@@ -327,10 +320,9 @@ static int process_ipmovie_chunk(IPMVECo
chunk_type = CHUNK_BAD;
break;
}
- s->fps = 1000000.0 / (AV_RL32(&scratch[0]) * AV_RL16(&scratch[4]));
- s->frame_pts_inc = 90000 / s->fps;
+ s->frame_pts_inc = ((uint64_t)AV_RL32(&scratch[0])) * AV_RL16(&scratch[4]);
debug_ipmovie(" %.2f frames/second (timer div = %d, subdiv = %d)\n",
- s->fps, AV_RL32(&scratch[0]), AV_RL16(&scratch[4]));
+ 1000000.0/s->frame_pts_inc, AV_RL32(&scratch[0]), AV_RL16(&scratch[4]));
break;
case OPCODE_INIT_AUDIO_BUFFERS:
@@ -554,7 +546,7 @@ static int ipmovie_read_header(AVFormatC
st = av_new_stream(s, 0);
if (!st)
return AVERROR(ENOMEM);
- av_set_pts_info(st, 33, 1, 90000);
+ av_set_pts_info(st, 63, 1, 1000000);
ipmovie->video_stream_index = st->index;
st->codec->codec_type = CODEC_TYPE_VIDEO;
st->codec->codec_id = CODEC_ID_INTERPLAY_VIDEO;
@@ -569,7 +561,7 @@ static int ipmovie_read_header(AVFormatC
st = av_new_stream(s, 0);
if (!st)
return AVERROR(ENOMEM);
- av_set_pts_info(st, 33, 1, 90000);
+ av_set_pts_info(st, 32, 1, ipmovie->audio_sample_rate);
ipmovie->audio_stream_index = st->index;
st->codec->codec_type = CODEC_TYPE_AUDIO;
st->codec->codec_id = ipmovie->audio_type;
More information about the ffmpeg-cvslog
mailing list