1
0
mirror of https://github.com/FFmpeg/FFmpeg.git synced 2024-11-26 19:01:44 +02:00

tiffenc: Simplify pixel format setup using AVPixFmtDescriptor.

This commit is contained in:
Alex Converse 2012-09-19 11:10:26 -07:00
parent 5e3f9979fa
commit 9bc055e358

View File

@ -27,6 +27,7 @@
#include "libavutil/log.h" #include "libavutil/log.h"
#include "libavutil/opt.h" #include "libavutil/opt.h"
#include "libavutil/pixdesc.h"
#include "avcodec.h" #include "avcodec.h"
#include "config.h" #include "config.h"
@ -219,6 +220,7 @@ static int encode_frame(AVCodecContext * avctx, AVPacket *pkt,
int is_yuv = 0; int is_yuv = 0;
uint8_t *yuv_line = NULL; uint8_t *yuv_line = NULL;
int shift_h, shift_v; int shift_h, shift_v;
const AVPixFmtDescriptor* pfd;
s->avctx = avctx; s->avctx = avctx;
@ -232,41 +234,35 @@ static int encode_frame(AVCodecContext * avctx, AVPacket *pkt,
s->subsampling[0] = 1; s->subsampling[0] = 1;
s->subsampling[1] = 1; s->subsampling[1] = 1;
s->bpp_tab_size = 0;
switch (avctx->pix_fmt) { switch (avctx->pix_fmt) {
case PIX_FMT_RGB48LE: case PIX_FMT_RGB48LE:
s->bpp = 48;
s->photometric_interpretation = 2;
s->bpp_tab_size = 3;
for (i = 0; i < s->bpp_tab_size; i++) {
bpp_tab[i] = 16;
}
break;
case PIX_FMT_GRAY16LE: case PIX_FMT_GRAY16LE:
s->bpp = 16;
s->photometric_interpretation = 1;
s->bpp_tab_size = 1;
bpp_tab[0] = 16;
break;
case PIX_FMT_RGB24: case PIX_FMT_RGB24:
s->bpp = 24;
s->photometric_interpretation = 2;
break;
case PIX_FMT_GRAY8: case PIX_FMT_GRAY8:
s->bpp = 8;
s->photometric_interpretation = 1;
break;
case PIX_FMT_PAL8: case PIX_FMT_PAL8:
s->bpp = 8; pfd = &av_pix_fmt_descriptors[avctx->pix_fmt];
s->photometric_interpretation = 3; s->bpp = av_get_bits_per_pixel(pfd);
if (pfd->flags & PIX_FMT_PAL) {
s->photometric_interpretation = 3;
} else if (pfd->flags & PIX_FMT_RGB) {
s->photometric_interpretation = 2;
} else {
s->photometric_interpretation = 1;
}
s->bpp_tab_size = pfd->nb_components;
for (i = 0; i < s->bpp_tab_size; i++) {
bpp_tab[i] = s->bpp / s->bpp_tab_size;
}
break; break;
case PIX_FMT_MONOBLACK: case PIX_FMT_MONOBLACK:
s->bpp = 1; s->bpp = 1;
s->photometric_interpretation = 1; s->photometric_interpretation = 1;
s->bpp_tab_size = 0;
break; break;
case PIX_FMT_MONOWHITE: case PIX_FMT_MONOWHITE:
s->bpp = 1; s->bpp = 1;
s->photometric_interpretation = 0; s->photometric_interpretation = 0;
s->bpp_tab_size = 0;
break; break;
case PIX_FMT_YUV420P: case PIX_FMT_YUV420P:
case PIX_FMT_YUV422P: case PIX_FMT_YUV422P:
@ -287,8 +283,6 @@ static int encode_frame(AVCodecContext * avctx, AVPacket *pkt,
"This colors format is not supported\n"); "This colors format is not supported\n");
return -1; return -1;
} }
if (!s->bpp_tab_size)
s->bpp_tab_size = (s->bpp >> 3);
if (s->compr == TIFF_DEFLATE || s->compr == TIFF_ADOBE_DEFLATE || s->compr == TIFF_LZW) if (s->compr == TIFF_DEFLATE || s->compr == TIFF_ADOBE_DEFLATE || s->compr == TIFF_LZW)
//best choose for DEFLATE //best choose for DEFLATE