Mercurial > mplayer.hg
changeset 482:1a2c4f3e7a10
sub control optimized
author | arpi_esp |
---|---|
date | Tue, 17 Apr 2001 00:08:56 +0000 |
parents | 6e8a887c99cd |
children | 92f170c8b9ba |
files | mplayer.c |
diffstat | 1 files changed, 79 insertions(+), 12 deletions(-) [+] |
line wrap: on
line diff
--- a/mplayer.c Mon Apr 16 22:27:32 2001 +0000 +++ b/mplayer.c Tue Apr 17 00:08:56 2001 +0000 @@ -94,26 +94,91 @@ static current_sub=0; static subtitle* subtitles=NULL; +static int nosub_range_start=-1; +static int nosub_range_end=-1; -void find_sub(unsigned long key){ +void find_sub(int key){ int i,j; - if(current_sub<0 || current_sub>=sub_num) current_sub=0; - vo_sub=&subtitles[current_sub]; - if(key>=vo_sub->start && key<=vo_sub->end) return; // OK! + if(vo_sub){ + if(key>=vo_sub->start && key<=vo_sub->end) return; // OK! + } else { + if(key>nosub_range_start && key<nosub_range_end) return; // OK! + } + // sub changed! + +// printf("\r---- sub changed ----\n"); + + // check next sub. + if(current_sub>=0 && current_sub+1<sub_num){ + if(key>subtitles[current_sub].end && key<subtitles[current_sub+1].start){ + // no sub + nosub_range_start=subtitles[current_sub].end; + nosub_range_end=subtitles[current_sub+1].start; + vo_sub=NULL; + return; + } + // next sub? + ++current_sub; + vo_sub=&subtitles[current_sub]; + if(key>=vo_sub->start && key<=vo_sub->end) return; // OK! + } + +// printf("\r---- sub log search... ----\n"); + // use logarithmic search: i=0;j=sub_num-1; // printf("Searching %d in %d..%d\n",key,subtitles[i].start,subtitles[j].end); while(j>=i){ current_sub=(i+j+1)/2; - if(key<subtitles[current_sub].start) - j=current_sub-1; - else - if(key>subtitles[current_sub].end) - i=current_sub+1; - else break; // found! + vo_sub=&subtitles[current_sub]; + if(key<vo_sub->start) j=current_sub-1; + else if(key>vo_sub->end) i=current_sub+1; + else return; // found! } - vo_sub=&subtitles[current_sub]; - if(key>=vo_sub->start && key<=vo_sub->end) return; // OK! +// if(key>=vo_sub->start && key<=vo_sub->end) return; // OK! + + // check where are we... + if(key<vo_sub->start){ + if(current_sub<=0){ + // before the first sub + nosub_range_start=key-1; // tricky + nosub_range_end=vo_sub->start; +// printf("FIRST... key=%d end=%d \n",key,vo_sub->start); + vo_sub=NULL; + return; + } + --current_sub; + if(key>subtitles[current_sub].end && key<subtitles[current_sub+1].start){ + // no sub + nosub_range_start=subtitles[current_sub].end; + nosub_range_end=subtitles[current_sub+1].start; +// printf("No sub... 1 \n"); + vo_sub=NULL; + return; + } + printf("HEH???? "); + } else { + if(key<=vo_sub->end) printf("JAJJ! "); else + if(current_sub+1>=sub_num){ + // at the end? + nosub_range_start=vo_sub->end; + nosub_range_end=0x7FFFFFFF; // MAXINT +// printf("END!?\n"); + vo_sub=NULL; + return; + } else + if(key>subtitles[current_sub].end && key<subtitles[current_sub+1].start){ + // no sub + nosub_range_start=subtitles[current_sub].end; + nosub_range_end=subtitles[current_sub+1].start; +// printf("No sub... 2 \n"); + vo_sub=NULL; + return; + } + } + + printf("SUB ERROR: %d ? %d --- %d [%d] \n",key,vo_sub->start,vo_sub->end,current_sub); + vo_sub=NULL; // no sub here } @@ -1919,7 +1984,9 @@ // find sub if(subtitles){ if(sub_fps==0) sub_fps=sh_video->fps; + current_module="find_sub"; find_sub(sub_uses_time?(100*(v_pts+sub_delay)):((v_pts+sub_delay)*sub_fps)); // FIXME! frame counter... + current_module=NULL; } }