[FFmpeg-devel] [PATCH] lavfi: add internal function ff_fill_rgba_map()

Mark Himsley mark at mdsh.com
Thu Oct 27 23:28:56 CEST 2011


On 26/10/2011 19:04, Stefano Sabatini wrote:
> ---
>   libavfilter/drawutils.c |   27 ++++++++++++++++-----------
>   libavfilter/drawutils.h |    2 ++
>   2 files changed, 18 insertions(+), 11 deletions(-)
>
> diff --git a/libavfilter/drawutils.c b/libavfilter/drawutils.c
> index dd9ceff..bf308a1 100644
> --- a/libavfilter/drawutils.c
> +++ b/libavfilter/drawutils.c
> @@ -23,16 +23,8 @@
>
>   enum { RED = 0, GREEN, BLUE, ALPHA };
>
> -int ff_fill_line_with_color(uint8_t *line[4], int pixel_step[4], int w, uint8_t dst_color[4],
> -                            enum PixelFormat pix_fmt, uint8_t rgba_color[4],
> -                            int *is_packed_rgba, uint8_t rgba_map_ptr[4])
> +int ff_fill_rgba_map(uint8_t *rgba_map, enum PixelFormat pix_fmt)
>   {
> -    uint8_t rgba_map[4] = {0};
> -    int i;
> -    const AVPixFmtDescriptor *pix_desc =&av_pix_fmt_descriptors[pix_fmt];
> -    int hsub = pix_desc->log2_chroma_w;
> -
> -    *is_packed_rgba = 1;
>       switch (pix_fmt) {
>       case PIX_FMT_ARGB:  rgba_map[ALPHA] = 0; rgba_map[RED  ] = 1; rgba_map[GREEN] = 2; rgba_map[BLUE ] = 3; break;
>       case PIX_FMT_ABGR:  rgba_map[ALPHA] = 0; rgba_map[BLUE ] = 1; rgba_map[GREEN] = 2; rgba_map[RED  ] = 3; break;
> @@ -40,9 +32,22 @@ int ff_fill_line_with_color(uint8_t *line[4], int pixel_step[4], int w, uint8_t
>       case PIX_FMT_RGB24: rgba_map[RED  ] = 0; rgba_map[GREEN] = 1; rgba_map[BLUE ] = 2; rgba_map[ALPHA] = 3; break;
>       case PIX_FMT_BGRA:
>       case PIX_FMT_BGR24: rgba_map[BLUE ] = 0; rgba_map[GREEN] = 1; rgba_map[RED  ] = 2; rgba_map[ALPHA] = 3; break;
> -    default:
> -        *is_packed_rgba = 0;
> +    default:                    /* unsupported */
> +        return AVERROR(EINVAL);
>       }
> +    return 0;
> +}

Thanks for adding this. It'll be very useful.

-- 
Mark


More information about the ffmpeg-devel mailing list