[FFmpeg-devel] [PATCH]Support gray16 png encoding

Carl Eugen Hoyos cehoyos at ag.or.at
Sat Jan 14 11:37:45 CET 2012


Hi!

Attached patch allows 16bit gray png encoding.

Please comment, Carl Eugen
-------------- next part --------------
diff --git a/libavcodec/pngenc.c b/libavcodec/pngenc.c
index b35402e..860219c 100644
--- a/libavcodec/pngenc.c
+++ b/libavcodec/pngenc.c
@@ -260,6 +260,10 @@ static int encode_frame(AVCodecContext *avctx, unsigned char *buf, int buf_size,
         bit_depth = 8;
         color_type = PNG_COLOR_TYPE_RGB;
         break;
+    case PIX_FMT_GRAY16BE:
+        bit_depth = 16;
+        color_type = PNG_COLOR_TYPE_GRAY;
+        break;
     case PIX_FMT_GRAY8:
         bit_depth = 8;
         color_type = PNG_COLOR_TYPE_GRAY;
@@ -443,6 +447,6 @@ AVCodec ff_png_encoder = {
     .priv_data_size = sizeof(PNGEncContext),
     .init           = png_enc_init,
     .encode         = encode_frame,
-    .pix_fmts= (const enum PixelFormat[]){PIX_FMT_RGB24, PIX_FMT_RGB32, PIX_FMT_PAL8, PIX_FMT_GRAY8, PIX_FMT_MONOBLACK, PIX_FMT_NONE},
+    .pix_fmts= (const enum PixelFormat[]){PIX_FMT_RGB24, PIX_FMT_RGB32, PIX_FMT_PAL8, PIX_FMT_GRAY8, PIX_FMT_GRAY16BE, PIX_FMT_MONOBLACK, PIX_FMT_NONE},
     .long_name= NULL_IF_CONFIG_SMALL("PNG image"),
 };


More information about the ffmpeg-devel mailing list