OSDN Git Service

use the adjustment value present in FLV to crop VP6 video
authorAurelien Jacobs <aurel@gnuage.org>
Sun, 22 Oct 2006 23:19:42 +0000 (23:19 +0000)
committerAurelien Jacobs <aurel@gnuage.org>
Sun, 22 Oct 2006 23:19:42 +0000 (23:19 +0000)
Originally committed as revision 6770 to svn://svn.ffmpeg.org/ffmpeg/trunk

libavcodec/vp6.c
libavformat/flvdec.c

index de6b61d..6d5d46b 100644 (file)
@@ -64,6 +64,10 @@ static int vp6_parse_header(vp56_context_t *s, uint8_t *buf, int buf_size,
         if (16*cols != s->avctx->coded_width ||
             16*rows != s->avctx->coded_height) {
             avcodec_set_dimensions(s->avctx, 16*cols, 16*rows);
+            if (s->avctx->extradata_size == 1) {
+                s->avctx->width  -= s->avctx->extradata[0] >> 4;
+                s->avctx->height -= s->avctx->extradata[0] & 0x0F;
+            }
             res = 2;
         }
 
index f9eefb1..87984b5 100644 (file)
@@ -193,7 +193,12 @@ static int flv_read_packet(AVFormatContext *s, AVPacket *pkt)
             case 3: st->codec->codec_id = CODEC_ID_FLASHSV; break;
             case 4:
                 st->codec->codec_id = CODEC_ID_VP6F;
-                get_byte(&s->pb); /* width and height adjustment */
+                if (st->codec->extradata_size != 1) {
+                    st->codec->extradata_size = 1;
+                    st->codec->extradata = av_malloc(1);
+                }
+                /* width and height adjustment */
+                st->codec->extradata[0] = get_byte(&s->pb);
                 size--;
                 break;
             default: