[FFmpeg-devel] [PATCH 01/13] avfilter/drawutils: Remove remnants of old API
Gyan Doshi
ffmpeg at gyani.pro
Fri Jan 29 20:59:45 EET 2021
Are there replacements or substitutes for these?
On 29-01-2021 10:52 am, Andreas Rheinhardt wrote:
> ff_fill_line_with_color and ff_draw_rectangle are unused since
> 19c8f2271423281c9b876b984076a6467c455904; ff_copy_rectangle
> is unused since 53b7a3fe081ec56c5706228eb6431bb943ad471a.
>
> Signed-off-by: Andreas Rheinhardt <andreas.rheinhardt at gmail.com>
> ---
> libavfilter/drawutils.c | 98 -----------------------------------------
> libavfilter/drawutils.h | 13 ------
> 2 files changed, 111 deletions(-)
>
> diff --git a/libavfilter/drawutils.c b/libavfilter/drawutils.c
> index 5f4cb548f0..71fe25692c 100644
> --- a/libavfilter/drawutils.c
> +++ b/libavfilter/drawutils.c
> @@ -77,104 +77,6 @@ int ff_fill_rgba_map(uint8_t *rgba_map, enum AVPixelFormat pix_fmt)
> return 0;
> }
>
> -int ff_fill_line_with_color(uint8_t *line[4], int pixel_step[4], int w, uint8_t dst_color[4],
> - enum AVPixelFormat pix_fmt, uint8_t rgba_color[4],
> - int *is_packed_rgba, uint8_t rgba_map_ptr[4])
> -{
> - uint8_t rgba_map[4] = {0};
> - int i;
> - const AVPixFmtDescriptor *pix_desc = av_pix_fmt_desc_get(pix_fmt);
> - int hsub;
> -
> - av_assert0(pix_desc);
> -
> - hsub = pix_desc->log2_chroma_w;
> -
> - *is_packed_rgba = ff_fill_rgba_map(rgba_map, pix_fmt) >= 0;
> -
> - if (*is_packed_rgba) {
> - pixel_step[0] = (av_get_bits_per_pixel(pix_desc))>>3;
> - for (i = 0; i < 4; i++)
> - dst_color[rgba_map[i]] = rgba_color[i];
> -
> - line[0] = av_malloc_array(w, pixel_step[0]);
> - if (!line[0])
> - return AVERROR(ENOMEM);
> - for (i = 0; i < w; i++)
> - memcpy(line[0] + i * pixel_step[0], dst_color, pixel_step[0]);
> - if (rgba_map_ptr)
> - memcpy(rgba_map_ptr, rgba_map, sizeof(rgba_map[0]) * 4);
> - } else {
> - int plane;
> -
> - dst_color[0] = RGB_TO_Y_CCIR(rgba_color[0], rgba_color[1], rgba_color[2]);
> - dst_color[1] = RGB_TO_U_CCIR(rgba_color[0], rgba_color[1], rgba_color[2], 0);
> - dst_color[2] = RGB_TO_V_CCIR(rgba_color[0], rgba_color[1], rgba_color[2], 0);
> - dst_color[3] = rgba_color[3];
> -
> - for (plane = 0; plane < 4; plane++) {
> - int line_size;
> - int hsub1 = (plane == 1 || plane == 2) ? hsub : 0;
> -
> - pixel_step[plane] = 1;
> - line_size = AV_CEIL_RSHIFT(w, hsub1) * pixel_step[plane];
> - line[plane] = av_malloc(line_size);
> - if (!line[plane]) {
> - while(plane && line[plane-1])
> - av_freep(&line[--plane]);
> - return AVERROR(ENOMEM);
> - }
> - memset(line[plane], dst_color[plane], line_size);
> - }
> - }
> -
> - return 0;
> -}
> -
> -void ff_draw_rectangle(uint8_t *dst[4], int dst_linesize[4],
> - uint8_t *src[4], int pixelstep[4],
> - int hsub, int vsub, int x, int y, int w, int h)
> -{
> - int i, plane;
> - uint8_t *p;
> -
> - for (plane = 0; plane < 4 && dst[plane]; plane++) {
> - int hsub1 = plane == 1 || plane == 2 ? hsub : 0;
> - int vsub1 = plane == 1 || plane == 2 ? vsub : 0;
> - int width = AV_CEIL_RSHIFT(w, hsub1);
> - int height = AV_CEIL_RSHIFT(h, vsub1);
> -
> - p = dst[plane] + (y >> vsub1) * dst_linesize[plane];
> - for (i = 0; i < height; i++) {
> - memcpy(p + (x >> hsub1) * pixelstep[plane],
> - src[plane], width * pixelstep[plane]);
> - p += dst_linesize[plane];
> - }
> - }
> -}
> -
> -void ff_copy_rectangle(uint8_t *dst[4], int dst_linesize[4],
> - uint8_t *src[4], int src_linesize[4], int pixelstep[4],
> - int hsub, int vsub, int x, int y, int y2, int w, int h)
> -{
> - int i, plane;
> - uint8_t *p;
> -
> - for (plane = 0; plane < 4 && dst[plane]; plane++) {
> - int hsub1 = plane == 1 || plane == 2 ? hsub : 0;
> - int vsub1 = plane == 1 || plane == 2 ? vsub : 0;
> - int width = AV_CEIL_RSHIFT(w, hsub1);
> - int height = AV_CEIL_RSHIFT(h, vsub1);
> -
> - p = dst[plane] + (y >> vsub1) * dst_linesize[plane];
> - for (i = 0; i < height; i++) {
> - memcpy(p + (x >> hsub1) * pixelstep[plane],
> - src[plane] + src_linesize[plane]*(i+(y2>>vsub1)), width * pixelstep[plane]);
> - p += dst_linesize[plane];
> - }
> - }
> -}
> -
> int ff_draw_init(FFDrawContext *draw, enum AVPixelFormat format, unsigned flags)
> {
> const AVPixFmtDescriptor *desc = av_pix_fmt_desc_get(format);
> diff --git a/libavfilter/drawutils.h b/libavfilter/drawutils.h
> index b999d70e55..2ca2475585 100644
> --- a/libavfilter/drawutils.h
> +++ b/libavfilter/drawutils.h
> @@ -30,19 +30,6 @@
>
> int ff_fill_rgba_map(uint8_t *rgba_map, enum AVPixelFormat pix_fmt);
>
> -int ff_fill_line_with_color(uint8_t *line[4], int pixel_step[4], int w,
> - uint8_t dst_color[4],
> - enum AVPixelFormat pix_fmt, uint8_t rgba_color[4],
> - int *is_packed_rgba, uint8_t rgba_map[4]);
> -
> -void ff_draw_rectangle(uint8_t *dst[4], int dst_linesize[4],
> - uint8_t *src[4], int pixelstep[4],
> - int hsub, int vsub, int x, int y, int w, int h);
> -
> -void ff_copy_rectangle(uint8_t *dst[4], int dst_linesize[4],
> - uint8_t *src[4], int src_linesize[4], int pixelstep[4],
> - int hsub, int vsub, int x, int y, int y2, int w, int h);
> -
> #define MAX_PLANES 4
>
> typedef struct FFDrawContext {
More information about the ffmpeg-devel
mailing list