summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--DOCS/man/en/mplayer.14
-rw-r--r--libvo/vo_png.c11
2 files changed, 13 insertions, 2 deletions
diff --git a/DOCS/man/en/mplayer.1 b/DOCS/man/en/mplayer.1
index 7ed4e19d56..064e72136c 100644
--- a/DOCS/man/en/mplayer.1
+++ b/DOCS/man/en/mplayer.1
@@ -4221,6 +4221,10 @@ Specifies the compression level.
0 is no compression, 9 is maximum compression.
.IPs outdir=<dirname>
Specify the directory to save the PNG files to (default: ./).
+.IPs alpha (default: noalpha)
+Create PNG files with an alpha channel.
+Note that MPlayer in general does not support alpha, so this will only
+be useful in some rare cases.
.RE
.PD 1
.
diff --git a/libvo/vo_png.c b/libvo/vo_png.c
index 7c0f439f69..84012b2d94 100644
--- a/libvo/vo_png.c
+++ b/libvo/vo_png.c
@@ -41,6 +41,7 @@ const LIBVO_EXTERN (png)
static int z_compression = Z_NO_COMPRESSION;
static char *png_outdir = NULL;
static int framenum = 0;
+static int use_alpha;
struct pngdata {
FILE * fp;
@@ -167,7 +168,7 @@ static struct pngdata create_png (char * fname, int image_width, int image_heigh
bit_depth, color_type, interlace_type,
compression_type, filter_type)*/
png_set_IHDR(png.png_ptr, png.info_ptr, image_width, image_height,
- 8, PNG_COLOR_TYPE_RGB, PNG_INTERLACE_NONE,
+ 8, use_alpha ? PNG_COLOR_TYPE_RGBA : PNG_COLOR_TYPE_RGB, PNG_INTERLACE_NONE,
PNG_COMPRESSION_TYPE_DEFAULT, PNG_FILTER_TYPE_DEFAULT);
mp_msg(MSGT_VO,MSGL_DBG2, "PNG Write Info\n");
@@ -246,10 +247,14 @@ static int draw_slice( uint8_t *src[],int stride[],int w,int h,int x,int y )
static int
query_format(uint32_t format)
{
+ const int supported_flags = VFCAP_CSP_SUPPORTED|VFCAP_CSP_SUPPORTED_BY_HW|VFCAP_ACCEPT_STRIDE;
switch(format){
case IMGFMT_RGB24:
case IMGFMT_BGR24:
- return VFCAP_CSP_SUPPORTED|VFCAP_CSP_SUPPORTED_BY_HW|VFCAP_ACCEPT_STRIDE;
+ return use_alpha ? 0 : supported_flags;
+ case IMGFMT_RGBA:
+ case IMGFMT_BGRA:
+ return use_alpha ? supported_flags : 0;
}
return 0;
}
@@ -271,6 +276,7 @@ static int int_zero_to_nine(int *sh)
}
static opt_t subopts[] = {
+ {"alpha", OPT_ARG_BOOL, &use_alpha, NULL, 0},
{"z", OPT_ARG_INT, &z_compression, (opt_test_f)int_zero_to_nine},
{"outdir", OPT_ARG_MSTRZ, &png_outdir, NULL, 0},
{NULL}
@@ -280,6 +286,7 @@ static int preinit(const char *arg)
{
z_compression = 0;
png_outdir = strdup(".");
+ use_alpha = 0;
if (subopt_parse(arg, subopts) != 0) {
return -1;
}