Commit 54077219 authored by michaelni's avatar michaelni

scene change detection


git-svn-id: file:///var/local/repositories/ffmpeg/trunk@337 9553f0bf-9b14-0410-a0b8-cfaf0461ba5b
parent 86bba471
...@@ -487,7 +487,6 @@ int MPV_encode_picture(AVCodecContext *avctx, ...@@ -487,7 +487,6 @@ int MPV_encode_picture(AVCodecContext *avctx,
} else { } else {
s->pict_type = I_TYPE; s->pict_type = I_TYPE;
} }
avctx->key_frame = (s->pict_type == I_TYPE);
MPV_frame_start(s); MPV_frame_start(s);
...@@ -518,6 +517,7 @@ int MPV_encode_picture(AVCodecContext *avctx, ...@@ -518,6 +517,7 @@ int MPV_encode_picture(AVCodecContext *avctx,
} }
encode_picture(s, s->picture_number); encode_picture(s, s->picture_number);
avctx->key_frame = (s->pict_type == I_TYPE);
MPV_frame_end(s); MPV_frame_end(s);
s->picture_number++; s->picture_number++;
...@@ -1078,6 +1078,18 @@ static void encode_picture(MpegEncContext *s, int picture_number) ...@@ -1078,6 +1078,18 @@ static void encode_picture(MpegEncContext *s, int picture_number)
} }
} }
if(s->avg_mb_var < s->mc_mb_var && s->pict_type != B_TYPE){ //FIXME subtract MV bits
int i;
s->pict_type= I_TYPE;
for(i=0; i<s->mb_height*s->mb_width; i++){
s->mb_type[i] = I_TYPE;
s->mv_table[0][i] = 0;
s->mv_table[1][i] = 0;
}
}
// printf("%d %d\n", s->avg_mb_var, s->mc_mb_var);
if (!s->fixed_qscale) if (!s->fixed_qscale)
s->qscale = rate_estimate_qscale(s); s->qscale = rate_estimate_qscale(s);
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment