[Mplayer-cvslog] CVS: main/libmpdemux demux_mov.c,1.19,1.20

Arpi of Ize arpi at mplayer.dev.hu
Mon Oct 29 22:55:27 CET 2001


Update of /cvsroot/mplayer/main/libmpdemux
In directory mplayer:/var/tmp.root/cvs-serv7538

Modified Files:
	demux_mov.c 
Log Message:
using keyframe info for seeking

Index: demux_mov.c
===================================================================
RCS file: /cvsroot/mplayer/main/libmpdemux/demux_mov.c,v
retrieving revision 1.19
retrieving revision 1.20
diff -u -r1.19 -r1.20
--- demux_mov.c	29 Oct 2001 21:25:10 -0000	1.19
+++ demux_mov.c	29 Oct 2001 21:55:07 -0000	1.20
@@ -71,6 +71,8 @@
     mov_chunkmap_t* chunkmap;
     int durmap_size;
     mov_durmap_t* durmap;
+    int keyframes_size;
+    unsigned int* keyframes;
 } mov_track_t;
 
 void mov_build_index(mov_track_t* trak){
@@ -372,15 +374,12 @@
 		int ver = (temp << 24);
 		int flags = (temp << 16)|(temp<<8)|temp;
 		int i;
-	
 		mp_msg(MSGT_DEMUX, MSGL_V,"MOV: %*sSyncing samples (keyframes) table! (%d entries) (ver:%d,flags:%ld)\n",
 		    level, "",entries, ver, flags);
-#if 0
-		for (i=0;i<entries;i++)
-		{
-		    printf("entry#%d: %ld\n", i, stream_read_dword(demuxer->stream));
-		}
-#endif
+		trak->keyframes_size=entries;
+		trak->keyframes=malloc(sizeof(unsigned int)*entries);
+		for (i=0;i<entries;i++) trak->keyframes[i]=stream_read_dword(demuxer->stream)-1;
+//		for (i=0;i<entries;i++) printf("%3d: %d\n",i,trak->keyframes[i]);
 		break;
 	    }
 	    case MOV_FOURCC('m','d','i','a'): {
@@ -751,8 +750,20 @@
     unsigned int ipts=pts;
 //    printf("MOV track seek - sample: %d  \n",ipts);
     if(!(flags&1)) ipts+=trak->samples[trak->pos].pts;
-    trak->pos=0;
-    while(trak->pos<trak->samples_size && trak->samples[trak->pos].pts<ipts) ++trak->pos;
+    for(trak->pos=0;trak->pos<trak->samples_size;++trak->pos){
+	if(trak->samples[trak->pos].pts>=ipts) break; // found it!
+    }
+    if(trak->keyframes_size){
+	// find nearest keyframe
+	int i;
+	for(i=0;i<trak->keyframes_size;i++){
+	    if(trak->keyframes[i]>=trak->pos) break;
+	}
+	if(i>0 && 
+	  (trak->keyframes[i]-trak->pos) > (trak->pos-trak->keyframes[i-1])) --i;
+	trak->pos=trak->keyframes[i];
+//	printf("nearest keyframe: %d  \n",trak->pos);
+    }
     pts=(float)trak->samples[trak->pos].pts/(float)trak->timescale;
 }
 




More information about the MPlayer-cvslog mailing list