Mercurial > mplayer.hg
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);