# HG changeset patch # User arpi # Date 999034504 0 # Node ID bdc1ec6fe668dbc2be5912f924f1ea8acb79cb54 # Parent bf80e7d70bc6bb2d273639ef6dbf02acee53f4f0 gui seekbar position fixed diff -r bf80e7d70bc6 -r bdc1ec6fe668 demux_mpg.c --- a/demux_mpg.c Tue Aug 28 19:35:34 2001 +0000 +++ b/demux_mpg.c Tue Aug 28 21:35:04 2001 +0000 @@ -234,7 +234,7 @@ mp_msg(MSGT_DEMUX,MSGL_WARN,"Encrypted stream but authentication was not requested by you!!\n"); } #endif - ds_read_packet(ds,demux->stream,len,pts/90000.0f,0,0); + ds_read_packet(ds,demux->stream,len,pts/90000.0f,demux->filepos,0); // if(ds==demux->sub) parse_dvdsub(ds->last->buffer,ds->last->len); return 1; } @@ -252,7 +252,7 @@ // Elementary video stream if(demux->stream->eof) return 0; demux->filepos=stream_tell(demux->stream); - ds_read_packet(demux->video,demux->stream,STREAM_BUFFER_SIZE,0,0,0); + ds_read_packet(demux->video,demux->stream,STREAM_BUFFER_SIZE,0,demux->filepos,0); return 1; } diff -r bf80e7d70bc6 -r bdc1ec6fe668 mplayer.c --- a/mplayer.c Tue Aug 28 19:35:34 2001 +0000 +++ b/mplayer.c Tue Aug 28 21:35:04 2001 +0000 @@ -1742,9 +1742,15 @@ #ifdef HAVE_NEW_GUI if(use_gui){ - int len=((demuxer->movi_end-demuxer->movi_start)); - if ( len > 0 ) mplShMem->Position=(float)(demuxer->filepos-demuxer->movi_start) / len * 100.0f; - else mplShMem->Position=0; + if(demuxer->file_format==DEMUXER_TYPE_AVI && sh_video->video.dwLength>2){ + // get pos from frame number / total frames + mplShMem->Position=(float)d_video->pack_no*100.0f/sh_video->video.dwLength; + } else { + // get pos from file position / filesize + int len=((demuxer->movi_end-demuxer->movi_start)); + int pos=(demuxer->file_format==DEMUXER_TYPE_AVI)?demuxer->filepos:d_video->pos; + mplShMem->Position=(len<=0)?0:((float)(pos-demuxer->movi_start) / len * 100.0f); + } mplShMem->TimeSec=d_video->pts; } #endif