changeset 31265:59f9bf345c0f

Extend -vf format to allow substituting the format for a compatible one (e.g. chaning rgb24 to bgr24).
author reimar
date Sat, 05 Jun 2010 17:55:20 +0000
parents f19d56a023db
children 649376ef332e
files DOCS/man/en/mplayer.1 libmpcodecs/vf_format.c
diffstat 2 files changed, 28 insertions(+), 3 deletions(-) [+]
line wrap: on
line diff
--- a/DOCS/man/en/mplayer.1	Sat Jun 05 17:45:35 2010 +0000
+++ b/DOCS/man/en/mplayer.1	Sat Jun 05 17:55:20 2010 +0000
@@ -6101,7 +6101,7 @@
 RGB/BGR 8 \-> 15/16/24/32bpp colorspace conversion using palette.
 .
 .TP
-.B format[=fourcc]
+.B format[=fourcc[:outfourcc]]
 Restricts the colorspace for the next filter without doing any conversion.
 Use together with the scale filter for a real conversion.
 .br
@@ -6111,6 +6111,17 @@
 .RSs
 .IPs <fourcc>
 format name like rgb15, bgr24, yv12, etc (default: yuy2)
+.IPs <outfourcc>
+Format name that should be substituted for the output.
+If this is not 100% compatible with the <fourcc> value it will crash.
+.br
+Valid examples:
+.br
+format=rgb24:bgr24 format=yuyv:yuy2
+.br
+Invalid examples (will crash):
+.br
+format=rgb24:yv12
 .RE
 .PD 1
 .
--- a/libmpcodecs/vf_format.c	Sat Jun 05 17:45:35 2010 +0000
+++ b/libmpcodecs/vf_format.c	Sat Jun 05 17:55:20 2010 +0000
@@ -34,28 +34,42 @@
 
 static struct vf_priv_s {
     unsigned int fmt;
+    unsigned int outfmt;
 } const vf_priv_dflt = {
-  IMGFMT_YUY2
+  IMGFMT_YUY2,
+  0
 };
 
 //===========================================================================//
 
 static int query_format(struct vf_instance *vf, unsigned int fmt){
-    if(fmt==vf->priv->fmt)
+    if(fmt==vf->priv->fmt) {
+        if (vf->priv->outfmt)
+            fmt = vf->priv->outfmt;
 	return vf_next_query_format(vf,fmt);
+    }
     return 0;
 }
 
+static int config(struct vf_instance *vf, int width, int height,
+                  int d_width, int d_height,
+                  unsigned flags, unsigned outfmt){
+    return vf_next_config(vf, width, height, d_width, d_height, flags, vf->priv->outfmt);
+}
+
 static int vf_open(vf_instance_t *vf, char *args){
     vf->query_format=query_format;
     vf->draw_slice=vf_next_draw_slice;
     vf->default_caps=0;
+    if (vf->priv->outfmt)
+        vf->config=config;
     return 1;
 }
 
 #define ST_OFF(f) M_ST_OFF(struct vf_priv_s,f)
 static const m_option_t vf_opts_fields[] = {
   {"fmt", ST_OFF(fmt), CONF_TYPE_IMGFMT, 0,0 ,0, NULL},
+  {"outfmt", ST_OFF(outfmt), CONF_TYPE_IMGFMT, 0,0 ,0, NULL},
   { NULL, NULL, 0, 0, 0, 0,  NULL }
 };