aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorCarl Eugen Hoyos <cehoyos@ag.or.at>2012-08-31 11:15:07 +0200
committerCarl Eugen Hoyos <cehoyos@ag.or.at>2012-08-31 11:15:07 +0200
commitf3683349aecf3be4c9c875186a812c0cde8ecf41 (patch)
tree0220db5840f880401a6863c18e8ee3cb0ada66ed
parent5eb532a9303079fb9a88f25708ea2ebda2ee9446 (diff)
downloadffmpeg-f3683349aecf3be4c9c875186a812c0cde8ecf41.tar.gz
Write TIFF Tag ExtraSamples when encoding pix_fmts that contain transparency information.
-rw-r--r--libavcodec/tiff.h1
-rw-r--r--libavcodec/tiffenc.c6
2 files changed, 6 insertions, 1 deletions
diff --git a/libavcodec/tiff.h b/libavcodec/tiff.h
index 0abeb8c096..6d760f0bd2 100644
--- a/libavcodec/tiff.h
+++ b/libavcodec/tiff.h
@@ -69,6 +69,7 @@ enum TiffTags{
TIFF_TILE_LENGTH = 0x143,
TIFF_TILE_OFFSETS = 0x144,
TIFF_TILE_BYTE_COUNTS = 0x145,
+ TIFF_EXTRASAMPLES = 0x152,
TIFF_YCBCR_COEFFICIENTS = 0x211,
TIFF_YCBCR_SUBSAMPLING = 0x212,
TIFF_YCBCR_POSITIONING = 0x213,
diff --git a/libavcodec/tiffenc.c b/libavcodec/tiffenc.c
index c3d0980595..4f6e734668 100644
--- a/libavcodec/tiffenc.c
+++ b/libavcodec/tiffenc.c
@@ -248,7 +248,7 @@ static int encode_frame(AVCodecContext * avctx, AVPacket *pkt,
uint32_t res[2] = { s->dpi, 1 }; // image resolution (72/1)
uint16_t bpp_tab[4];
int ret = -1;
- int is_yuv = 0;
+ int is_yuv = 0, alpha = 0;
int shift_h, shift_v;
*p = *pict;
@@ -264,6 +264,7 @@ static int encode_frame(AVCodecContext * avctx, AVPacket *pkt,
switch (avctx->pix_fmt) {
case PIX_FMT_RGBA64LE:
case PIX_FMT_RGBA:
+ alpha = 1;
case PIX_FMT_RGB48LE:
case PIX_FMT_RGB24:
s->photometric_interpretation = 2;
@@ -271,6 +272,7 @@ static int encode_frame(AVCodecContext * avctx, AVPacket *pkt,
case PIX_FMT_GRAY8:
avctx->bits_per_coded_sample = 0x28;
case PIX_FMT_GRAY8A:
+ alpha = avctx->pix_fmt == PIX_FMT_GRAY8A;
case PIX_FMT_GRAY16LE:
case PIX_FMT_MONOBLACK:
s->photometric_interpretation = 1;
@@ -451,6 +453,8 @@ static int encode_frame(AVCodecContext * avctx, AVPacket *pkt,
}
add_entry(s, TIFF_PAL, TIFF_SHORT, 256 * 3, pal);
}
+ if (alpha)
+ add_entry1(s,TIFF_EXTRASAMPLES, TIFF_SHORT, 2);
if (is_yuv){
/** according to CCIR Recommendation 601.1 */
uint32_t refbw[12] = {15, 1, 235, 1, 128, 1, 240, 1, 128, 1, 240, 1};