[FFmpeg-soc] [soc]: r5782 - libavfilter/vf_overlay.c
Stefano Sabatini
stefano.sabatini-lala at poste.it
Wed May 12 01:44:23 CEST 2010
On date Tuesday 2010-05-11 15:54:21 -0700, Baptiste Coudurier encoded:
> On 05/01/2010 03:44 PM, stefano wrote:
> >Author: stefano
> >Date: Sun May 2 00:44:49 2010
> >New Revision: 5782
> >
> >Log:
> >Make config_input_main() use pixdesc.h for computing chroma offsets
> >and bits per pixel, simplify.
> >
> >Modified:
> > libavfilter/vf_overlay.c
> >
> >Modified: libavfilter/vf_overlay.c
> >==============================================================================
> >--- libavfilter/vf_overlay.c Sun May 2 00:17:55 2010 (r5781)
> >+++ libavfilter/vf_overlay.c Sun May 2 00:44:49 2010 (r5782)
> >@@ -26,6 +26,7 @@
> > #include<stdio.h>
> >
> > #include "avfilter.h"
> >+#include "libavutil/pixdesc.h"
> > #include "libavcodec/eval.h"
> > #include "libavutil/avstring.h"
> >
> >@@ -108,28 +109,9 @@ static int config_input_main(AVFilterLin
> > {
> > OverlayContext *over = link->dst->priv;
> >
> >- switch(link->format) {
> >- case PIX_FMT_RGB32:
> >- case PIX_FMT_BGR32:
> >- over->bpp = 4;
> >- break;
> >- case PIX_FMT_RGB24:
> >- case PIX_FMT_BGR24:
> >- over->bpp = 3;
> >- break;
> >- case PIX_FMT_RGB565:
> >- case PIX_FMT_RGB555:
> >- case PIX_FMT_BGR565:
> >- case PIX_FMT_BGR555:
> >- case PIX_FMT_GRAY16BE:
> >- case PIX_FMT_GRAY16LE:
> >- over->bpp = 2;
> >- break;
> >- default:
> >- over->bpp = 1;
> >- }
> >-
> >- avcodec_get_chroma_sub_sample(link->format,&over->hsub,&over->vsub);
> >+ over->bpp = (av_get_bits_per_pixel(&av_pix_fmt_descriptors[link->format]) + 7)>> 3;
> >+ over->hsub = av_pix_fmt_descriptors[link->format].log2_chroma_w;
> >+ over->vsub = av_pix_fmt_descriptors[link->format].log2_chroma_h;
> >
>
> Humm this seems to break the filter.
> bpp was 1 for yuv before this change, now it is 2.
> bpp is used to offset x from pic->data per component, which seems
> not related to the value av_get_bits_per_pixel returns.
Doh I'm stupid - reverted. That can be achieved in a general/elegant
way using pixdescs, but now it is too late/I'm too tired for that.
Regards.
More information about the FFmpeg-soc
mailing list