changeset 9517:d65ddafbc404

clean up of -geometry code. disabled -geometry for all but -vo xv (will be fixed later)
author attila
date Sun, 02 Mar 2003 21:09:15 +0000
parents 1a98dc5021ef
children 182d6c136095
files DOCS/en/mplayer.1 libvo/geometry.c libvo/geometry.h libvo/vo_fbdev.c libvo/vo_tdfxfb.c libvo/vo_xv.c mplayer.c
diffstat 7 files changed, 59 insertions(+), 42 deletions(-) [+]
line wrap: on
line diff
--- a/DOCS/en/mplayer.1	Sun Mar 02 15:58:25 2003 +0000
+++ b/DOCS/en/mplayer.1	Sun Mar 02 21:09:15 2003 +0000
@@ -1449,8 +1449,7 @@
 option.
 The values given must be integers.
 
-Note: This option is only supported by a few vo's, including tdfxfb, fbdev and
-xv.
+Note: This option is only supported by one vo: xv.
 
 .I EXAMPLE:
 .PD 0
--- a/libvo/geometry.c	Sun Mar 02 15:58:25 2003 +0000
+++ b/libvo/geometry.c	Sun Mar 02 21:09:15 2003 +0000
@@ -16,47 +16,68 @@
 	return 0;
 }
 
-// A little kludge as to not to have to update all drivers
-// Only the vo_xv driver supports now the full [WxH][+X+Y] option
-int geometryFull(int *pwidth, int *pheight, int *xpos, int *ypos, int scrw, int scrh, int vidw, int vidh)
+#define RESET_GEOMETRY width = height = xoff = yoff = xper = yper = -1;
+
+// xpos,ypos: position of the left upper corner
+// widw,widh: width and height of the window
+// scrw,scrh: width and height of the current screen 
+int geometry(int *xpos, int *ypos, int *widw, int *widh, int scrw, int scrh)
 {
         int width, height, xoff, yoff, xper, yper;
 
 	width = height = xoff = yoff = xper = yper = -1;
 
-	/* no need to save a few extra cpu cycles here ;) */
-	/* PUKE i will rewrite this code sometime maybe - euck but it works */
         if(vo_geometry != NULL) {
-		if(sscanf(vo_geometry, "%ix%i+%i+%i", &width, &height, &xoff, &yoff) != 4 &&
-		   sscanf(vo_geometry, "%ix%i", &width, &height) != 2 &&
-		   sscanf(vo_geometry, "+%i+%i", &xoff, &yoff) != 2 &&
-		   sscanf(vo_geometry, "%i:%i", &xoff, &yoff) != 2 &&
-		   sscanf(vo_geometry, "%i:%i%%", &xper, &yper) != 2 &&
-		   sscanf(vo_geometry, "%i%%:%i", &xper, &yper) != 2 &&
-		   sscanf(vo_geometry, "%i%%:%i%%", &xper, &yper) != 2 &&
-		   sscanf(vo_geometry, "%i%%", &xper) != 1)
+		if(sscanf(vo_geometry, "%ix%i+%i+%i", &width, &height, &xoff, &yoff) != 4 )
+		{
+		 RESET_GEOMETRY
+		 if(sscanf(vo_geometry, "%ix%i", &width, &height) != 2)
+		 {
+		  RESET_GEOMETRY
+		  if(sscanf(vo_geometry, "+%i+%i", &xoff, &yoff) != 2)
+		  {
+		   RESET_GEOMETRY
+		   if(sscanf(vo_geometry, "%i:%i", &xoff, &yoff) != 2)
+		   {
+		    RESET_GEOMETRY
+		    if(sscanf(vo_geometry, "%i:%i%%", &xper, &yper) != 2)
+		    {
+		     RESET_GEOMETRY
+		     if(sscanf(vo_geometry, "%i%%:%i", &xper, &yper) != 2)
+		     {
+		     RESET_GEOMETRY
+		     if(sscanf(vo_geometry, "%i%%:%i%%", &xper, &yper) != 2)
+		     {
+		      RESET_GEOMETRY
+		      if(sscanf(vo_geometry, "%i%%", &xper) != 1)
 			return geometry_error();
+		     }
+		    }
+		   }
+		  }
+		 }
+		}
+	       }
 
-		if(xper >= 0 && xper <= 100) xoff = (scrw - vidw) * ((float)xper / 100.0);
-		if(yper >= 0 && yper <= 100) yoff = (scrh - vidh) * ((float)yper / 100.0);
+		mp_msg(MSGT_VO, MSGL_V,"geometry set to width: %i,"
+		  "height: %i, xoff: %i, yoff: %i, xper: %1, yper: %i\n",
+		  width, height, xoff, yoff, xper, yper);
+		  
+		if(xper >= 0 && xper <= 100) xoff = (scrw - *widw) * ((float)xper / 100.0);
+		if(yper >= 0 && yper <= 100) yoff = (scrh - *widh) * ((float)yper / 100.0);
 
 		/* FIXME: better checking of bounds... */
-		if(width < 0 || width > scrw) width = vidw;
-		if(height < 0 || height > scrh) height = vidh;
-		if(xoff < 0 || xoff + vidw > scrw) xoff = 0;
-		if(yoff < 0 || yoff + vidh > scrh) yoff = 0;
+		if(width < 0 || width > scrw) width = *widw;
+		if(height < 0 || height > scrh) height = *widh;
+		if(xoff < 0 || xoff + *widw > scrw) xoff = 0;
+		if(yoff < 0 || yoff + *widh > scrh) yoff = 0;
 
 		if(xpos) *xpos = xoff;
 		if(ypos) *ypos = yoff;
-		if(pwidth) *pwidth = width;
-		if(pheight) *pheight = height;
+		if(widw) *widw = width;
+		if(widh) *widh = height;
         }
 	return 1;
 }
 
-// compatibility function
-// only libvo working with full geometry options.
-int geometry(int *xpos, int *ypos, int scrw, int scrh, int vidw, int vidh)
-{
-  return geometryFull(NULL, NULL, xpos, ypos, scrw, scrh, vidw, vidh);
-}
+#undef RESET_GEOMETRY
--- a/libvo/geometry.h	Sun Mar 02 15:58:25 2003 +0000
+++ b/libvo/geometry.h	Sun Mar 02 21:09:15 2003 +0000
@@ -3,7 +3,5 @@
 #define __GEOMETRY_H
 
 extern char *vo_geometry;
-int geometryFull(int *pwidth, int *pheight, int *xpos, int *ypos, int scrw, int scrh, int vidw, int vidh);
-int geometry(int *xpos, int *ypos, int scrw, int scrh, int vidw, int vidh);
-
+int geometry(int *xpos, int *ypos, int *widw, int *widh, int scrw, int scrh);
 #endif /* !__GEOMETRY_H */
--- a/libvo/vo_fbdev.c	Sun Mar 02 15:58:25 2003 +0000
+++ b/libvo/vo_fbdev.c	Sun Mar 02 21:09:15 2003 +0000
@@ -1046,7 +1046,9 @@
 		if(fb_yres > image_height)
 		    y_offset = (fb_yres - image_height) / 2;
 		else y_offset = 0;
-		geometry(&x_offset,&y_offset,fb_xres,fb_yres,image_width,image_height);
+
+		//FIXME: update geometry code
+		//geometry(&x_offset,&y_offset,fb_xres,fb_yres,image_width,image_height);
 
 		if(vidix_init(width,height,x_offset,y_offset,image_width,
 			    image_height,format,fb_bpp,
@@ -1070,7 +1072,8 @@
 		return 1;
 	    }
 
-	    geometry(&x_offset,&y_offset,fb_xres,fb_yres,out_width,out_height);
+	    //FIXME: update geometry code
+	    //geometry(&x_offset,&y_offset,fb_xres,fb_yres,out_width,out_height);
 
 	    L123123875 = frame_buffer + (out_width - in_width) * fb_pixel_size /
 		    2 + ( (out_height - in_height) / 2 ) * fb_line_len +
--- a/libvo/vo_tdfxfb.c	Sun Mar 02 15:58:25 2003 +0000
+++ b/libvo/vo_tdfxfb.c	Sun Mar 02 21:09:15 2003 +0000
@@ -204,7 +204,9 @@
 static void setup_screen(uint32_t full)
 {
 	aspect(&vidwidth, &vidheight, full ? A_ZOOM : A_NOZOOM);
-	geometry(&vidx, &vidy, screenwidth, screenheight, vidwidth, vidheight);
+
+	//FIXME: update geometry code
+	//geometry(&vidx, &vidy, screenwidth, screenheight, vidwidth, vidheight);
 	vo_fs = full;
 	clear_screen();
 }
--- a/libvo/vo_xv.c	Sun Mar 02 15:58:25 2003 +0000
+++ b/libvo/vo_xv.c	Sun Mar 02 21:09:15 2003 +0000
@@ -282,7 +282,7 @@
  vo_mouse_autohide=1;
 
  vo_dx=( vo_screenwidth - d_width ) / 2; vo_dy=( vo_screenheight - d_height ) / 2;
- geometry(&vo_dx, &vo_dy, vo_screenwidth, vo_screenheight, d_width, d_height);
+ geometry(&vo_dx, &vo_dy, &d_width, &d_height, vo_screenwidth, vo_screenheight);
  vo_dwidth=d_width; vo_dheight=d_height;
      
 #ifdef HAVE_XF86VM
--- a/mplayer.c	Sun Mar 02 15:58:25 2003 +0000
+++ b/mplayer.c	Sun Mar 02 21:09:15 2003 +0000
@@ -110,9 +110,6 @@
 //**************************************************************************//
 //             Config
 //**************************************************************************//
-
-#include "libvo/geometry.h"
-
 m_config_t* mconfig;
 
 #ifdef NEW_CONFIG
@@ -736,9 +733,6 @@
     if(m_config_parse_command_line(mconfig, argc, argv) < 0) exit(1); // error parsing cmdline
 #endif
 
-    geometryFull(&opt_screen_size_x, &opt_screen_size_y, NULL, NULL,
-	vo_screenwidth, vo_screenheight, vo_screenwidth, vo_screenheight);
-
     playtree = play_tree_cleanup(playtree);
     if(playtree) {
       playtree_iter = play_tree_iter_new(playtree,mconfig);