[SCM] libav/experimental: set pict_type & key_frame on decoding too
siretart at users.alioth.debian.org
siretart at users.alioth.debian.org
Sun Jun 30 15:33:15 UTC 2013
The following commit has been merged in the experimental branch:
commit 208d3ddf961c745b20e19f1568dca3f631856d34
Author: Michael Niedermayer <michaelni at gmx.at>
Date: Thu Sep 12 00:27:08 2002 +0000
set pict_type & key_frame on decoding too
Originally committed as revision 918 to svn://svn.ffmpeg.org/ffmpeg/trunk
diff --git a/libavcodec/avcodec.h b/libavcodec/avcodec.h
index 96db4d9..123c58f 100644
--- a/libavcodec/avcodec.h
+++ b/libavcodec/avcodec.h
@@ -182,7 +182,7 @@ typedef struct AVCodecContext {
int key_frame; /* true if the previous compressed frame was
a key frame (intra, or seekable) */
int pict_type; /* picture type of the previous
- encoded frame */
+ en/decoded frame */
/* FIXME: these should have FF_ */
#define I_TYPE 1 // Intra
#define P_TYPE 2 // Predicted
diff --git a/libavcodec/mpegvideo.c b/libavcodec/mpegvideo.c
index e26024c..619cf50 100644
--- a/libavcodec/mpegvideo.c
+++ b/libavcodec/mpegvideo.c
@@ -720,7 +720,8 @@ void MPV_frame_start(MpegEncContext *s, AVCodecContext *avctx)
/* generic function for encode/decode called after a frame has been coded/decoded */
void MPV_frame_end(MpegEncContext *s)
{
-// if((s->picture_number%100)==0 && s->encoding) printf("sads:%d //\n", sads);
+ s->avctx->key_frame = (s->pict_type == I_TYPE);
+ s->avctx->pict_type = s->pict_type;
/* draw edge for correct motion prediction if outside */
if (s->pict_type != B_TYPE && !s->intra_only && !(s->flags&CODEC_FLAG_EMU_EDGE)) {
@@ -870,8 +871,7 @@ int MPV_encode_picture(AVCodecContext *avctx,
MPV_frame_start(s, avctx);
encode_picture(s, s->picture_number);
- avctx->key_frame = (s->pict_type == I_TYPE);
- avctx->pict_type = s->pict_type;
+
avctx->real_pict_num = s->picture_number;
avctx->header_bits = s->header_bits;
avctx->mv_bits = s->mv_bits;
--
Libav/FFmpeg packaging
More information about the pkg-multimedia-commits
mailing list