Mercurial > libavcodec.hg
changeset 12468:443f38ceeaad libavcodec
Reimplement av_picture_data_copy() avoiding the use of PixFmtInfo
information.
Required for moving the function to libavcore.
author | stefano |
---|---|
date | Tue, 07 Sep 2010 21:23:52 +0000 |
parents | 94275c8cd57d |
children | 9471234fb8ea |
files | imgconvert.c |
diffstat | 1 files changed, 17 insertions(+), 16 deletions(-) [+] |
line wrap: on
line diff
--- a/imgconvert.c Tue Sep 07 21:23:48 2010 +0000 +++ b/imgconvert.c Tue Sep 07 21:23:52 2010 +0000 @@ -799,17 +799,26 @@ uint8_t *src_data[4], int src_linesize[4], enum PixelFormat pix_fmt, int width, int height) { - int i; - const PixFmtInfo *pf = &pix_fmt_info[pix_fmt]; const AVPixFmtDescriptor *desc = &av_pix_fmt_descriptors[pix_fmt]; - switch(pf->pixel_type) { - case FF_PIXEL_PACKED: - case FF_PIXEL_PLANAR: - for(i = 0; i < pf->nb_channels; i++) { - int h; + if (desc->flags & PIX_FMT_HWACCEL) + return; + + if (desc->flags & PIX_FMT_PAL) { + av_image_copy_plane(dst_data[0], dst_linesize[0], + src_data[0], src_linesize[0], + width, height); + /* copy the palette */ + memcpy(dst_data[1], src_data[1], 4*256); + } else { + int i, planes_nb = 0; + + for (i = 0; i < desc->nb_components; i++) + planes_nb = FFMAX(planes_nb, desc->comp[i].plane + 1); + + for (i = 0; i < planes_nb; i++) { + int h = height; int bwidth = av_image_get_linesize(pix_fmt, width, i); - h = height; if (i == 1 || i == 2) { h= -((-height)>>desc->log2_chroma_h); } @@ -817,14 +826,6 @@ src_data[i], src_linesize[i], bwidth, h); } - break; - case FF_PIXEL_PALETTE: - av_image_copy_plane(dst_data[0], dst_linesize[0], - src_data[0], src_linesize[0], - width, height); - /* copy the palette */ - memcpy(dst_data[1], src_data[1], 4*256); - break; } }