From 1cdfbc1fbc12039d0518f2018fecddc39ccbb239 Mon Sep 17 00:00:00 2001 From: alex Date: Fri, 28 Dec 2001 22:58:49 +0000 Subject: Applied Rik Snel's seeking patch git-svn-id: svn://svn.mplayerhq.hu/mplayer/trunk@3864 b3059339-0415-0410-9bf9-f77b7e298cf2 --- libmpdemux/demux_y4m.c | 36 +++++++++++++++++++++++++++++++----- libmpdemux/demuxer.c | 4 ++++ 2 files changed, 35 insertions(+), 5 deletions(-) diff --git a/libmpdemux/demux_y4m.c b/libmpdemux/demux_y4m.c index 9aa2158bd6..8cfcc2b537 100644 --- a/libmpdemux/demux_y4m.c +++ b/libmpdemux/demux_y4m.c @@ -88,7 +88,7 @@ int demux_y4m_fill_buffer(demuxer_t *demux) { return 0; /* EOF */ if (c != 'F') { - printf("Bad frame at %p\n", stream_tell(demux->stream)-1); + mp_msg(MSGT_DEMUX, MSGL_V, "Bad frame at %d\n", (int)stream_tell(demux->stream)-1); return 0; } stream_skip(demux->stream, 5); /* RAME\n */ @@ -128,7 +128,6 @@ void demux_open_y4m(demuxer_t* demuxer){ char buf[4]; int frame_rate_code; - priv->framenum = 1; stream_skip(demuxer->stream, 8); /* YUV4MPEG */ stream_skip(demuxer->stream, 1); /* space */ stream_read(demuxer->stream, (char *)&buf[0], 3); @@ -200,6 +199,7 @@ void demux_open_y4m(demuxer_t* demuxer){ sh->disp_w = y4m_si_get_width(priv->si); sh->disp_h = y4m_si_get_height(priv->si); + demuxer->seekable = 0; } sh->format = mmioFOURCC('Y', 'V', '1', '2'); @@ -218,14 +218,40 @@ void demux_open_y4m(demuxer_t* demuxer){ sh->ds=demuxer->video; demuxer->video->id=0; - /* disable seeking, lazy */ - demuxer->seekable = 0; - printf("YUV4MPEG2 Video stream %d size: display: %dx%d, codec: %ux%u\n", + mp_msg(MSGT_DEMUX, MSGL_INFO, "YUV4MPEG2 Video stream %d size: display: %dx%d, codec: %ux%u\n", demuxer->video->id, sh->disp_w, sh->disp_h, sh->bih->biWidth, sh->bih->biHeight); } +int demux_seek_y4m(demuxer_t *demuxer, float rel_seek_secs, int flags) { + sh_video_t* sh = demuxer->video->sh; + y4m_priv_t* priv = demuxer->priv; + int rel_seek_frames = sh->fps*rel_seek_secs; + int size = 3*sh->disp_w*sh->disp_h/2; + off_t curr_pos = stream_tell(demuxer->stream); + + if (priv->framenum + rel_seek_frames < 0) rel_seek_frames = -priv->framenum; + + //printf("seektoframe=%d rel_seek_secs=%f seektooffset=%ld\n", priv->framenum + rel_seek_frames, rel_seek_secs, curr_pos + rel_seek_frames*(size+6)); + //printf("framenum=%d, curr_pos=%ld, currpos/(size+6)=%f\n", priv->framenum, curr_pos, (float)curr_pos/(float)(size+6)); + priv->framenum += rel_seek_frames; + + if (priv->is_older) { + /* Well this is easy: every frame takes up size+6 bytes + * in the stream and we may assume that the stream pointer + * is always at the beginning of a frame. + * framenum is the number of the frame that is about to be + * demuxed (counting from ONE (see demux_open_y4m)) */ + stream_seek(demuxer->stream, curr_pos + rel_seek_frames*(size+6)); + } else { + /* should never come here, because seeking for YUV4MPEG2 + * is disabled. */ + mp_msg(MSGT_DEMUX, MSGL_WARN, "Seeking for YUV4MPEG2 not yet implemented!\n"); + } + return 0; +} + void demux_close_y4m(demuxer_t *demuxer) { y4m_priv_t* priv = demuxer->priv; diff --git a/libmpdemux/demuxer.c b/libmpdemux/demuxer.c index faf6b9ac68..f89d92f4b3 100644 --- a/libmpdemux/demuxer.c +++ b/libmpdemux/demuxer.c @@ -658,6 +658,7 @@ return demuxer; int demux_seek_avi(demuxer_t *demuxer,float rel_seek_secs,int flags); int demux_seek_asf(demuxer_t *demuxer,float rel_seek_secs,int flags); int demux_seek_mpg(demuxer_t *demuxer,float rel_seek_secs,int flags); +int demux_seek_y4m(demuxer_t *demuxer,float rel_seek_secs,int flags); int demux_seek_fli(demuxer_t *demuxer,float rel_seek_secs,int flags); void demux_seek_mov(demuxer_t *demuxer,float pts,int flags); @@ -709,6 +710,9 @@ switch(demuxer->file_format){ case DEMUXER_TYPE_MOV: demux_seek_mov(demuxer,rel_seek_secs,flags); break; + case DEMUXER_TYPE_Y4M: + demux_seek_y4m(demuxer,rel_seek_secs,flags); break; + case DEMUXER_TYPE_FLI: demux_seek_fli(demuxer,rel_seek_secs,flags); break; -- cgit v1.2.3