Mercurial > mplayer.hg
changeset 17647:1b74cb09e9c1
deobfuscate some a/v sync code
author | ods15 |
---|---|
date | Sun, 19 Feb 2006 04:31:14 +0000 |
parents | 168d8eb397f1 |
children | 5963b50c2178 |
files | mencoder.c |
diffstat | 1 files changed, 15 insertions(+), 14 deletions(-) [+] |
line wrap: on
line diff
--- a/mencoder.c Sat Feb 18 21:12:56 2006 +0000 +++ b/mencoder.c Sun Feb 19 04:31:14 2006 +0000 @@ -1274,29 +1274,30 @@ // check frame duplicate/drop: //printf("\r### %5.3f ###\n",v_timer_corr); +float mux_frametime = (float)mux_v->h.dwScale/mux_v->h.dwRate; -if(v_timer_corr>=(float)mux_v->h.dwScale/mux_v->h.dwRate && - (skip_limit<0 || skip_flag<skip_limit) ){ - v_timer_corr-=(float)mux_v->h.dwScale/mux_v->h.dwRate; +if (v_timer_corr >= mux_frametime && (skip_limit<0 || skip_flag < skip_limit)) { + v_timer_corr-=mux_frametime; ++skip_flag; // skip -} else -while(v_timer_corr<=-(float)mux_v->h.dwScale/mux_v->h.dwRate && - (skip_limit<0 || (-skip_flag)<skip_limit) ){ - v_timer_corr+=(float)mux_v->h.dwScale/mux_v->h.dwRate; +} +while (v_timer_corr <= -mux_frametime && (skip_limit<0 || -skip_flag < skip_limit)) { + v_timer_corr+=mux_frametime; --skip_flag; // dup } -while( (v_pts_corr<=-(float)mux_v->h.dwScale/mux_v->h.dwRate && skip_flag>0) - || (v_pts_corr<=-2*(float)mux_v->h.dwScale/mux_v->h.dwRate) ){ - v_pts_corr+=(float)mux_v->h.dwScale/mux_v->h.dwRate; +// either v_pts_corr is big, more than 2 times framerate, then we follow its advice, +// or, it cancels out v_timer_corr, in which case be happy and do nothing. + +while ((v_pts_corr <= -mux_frametime && skip_flag > 0) || (v_pts_corr <= -2*mux_frametime)) { + v_pts_corr+=mux_frametime; --skip_flag; // dup } -if( (v_pts_corr>=(float)mux_v->h.dwScale/mux_v->h.dwRate && skip_flag<0) - || (v_pts_corr>=2*(float)mux_v->h.dwScale/mux_v->h.dwRate) ) - if(skip_flag<=0){ // we can't skip more than 1 frame now - v_pts_corr-=(float)mux_v->h.dwScale/mux_v->h.dwRate; +if ((v_pts_corr >= mux_frametime && skip_flag < 0) || (v_pts_corr >= 2*mux_frametime)) { + if (skip_flag<=0) { // we can't skip more than 1 frame now + v_pts_corr-=mux_frametime; ++skip_flag; // skip } +} } // demuxer2