diff options
author | mgraffam <mgraffam@b3059339-0415-0410-9bf9-f77b7e298cf2> | 2001-03-24 21:31:37 +0000 |
---|---|---|
committer | mgraffam <mgraffam@b3059339-0415-0410-9bf9-f77b7e298cf2> | 2001-03-24 21:31:37 +0000 |
commit | d1b372c1a2d1d46be7c25d93d2cf801c16da6426 (patch) | |
tree | cb5014f82e38e5b51e87f7dd5ed47bed6429e82e | |
parent | 752de843ff036132da06752d753dd12b0ad5e529 (diff) |
adds XF86VidMode support to vo_x11.c to do "pseudo-scaling"
uses d_width, d_height when in fullscreen mode to switch to a
desired modeline.
git-svn-id: svn://svn.mplayerhq.hu/mplayer/trunk@207 b3059339-0415-0410-9bf9-f77b7e298cf2
-rw-r--r-- | libvo/vo_x11.c | 65 |
1 files changed, 65 insertions, 0 deletions
diff --git a/libvo/vo_x11.c b/libvo/vo_x11.c index bf8b5abe14..cf3588105c 100644 --- a/libvo/vo_x11.c +++ b/libvo/vo_x11.c @@ -28,6 +28,9 @@ LIBVO_EXTERN( x11 ) #include <X11/Xlib.h> #include <X11/Xutil.h> #include <X11/extensions/XShm.h> +#ifdef HAVE_XF86VM +#include <X11/extensions/xf86vmode.h> +#endif #include <errno.h> #include "yuv2rgb.h" @@ -50,6 +53,10 @@ int XShmGetEventBase( Display* ); /* local data */ static unsigned char *ImageData; +#ifdef HAVE_XF86VM +XF86VidModeModeInfo **vidmodes=NULL; +#endif + /* X11 related variables */ static Display *mDisplay; static Window mywindow; @@ -138,6 +145,54 @@ static uint32_t init( uint32_t width,uint32_t height,uint32_t d_width,uint32_t d hint.y=0; hint.width=image_width; hint.height=image_height; + +#ifdef HAVE_XF86VM + if (fullscreen) { + unsigned int modeline_width, modeline_height, vm_event, vm_error; + unsigned int vm_ver, vm_rev; + int i,j,k,have_vm=0,X,Y; + + int modecount; + + if (XF86VidModeQueryExtension(mDisplay, &vm_event, &vm_error)) { + XF86VidModeQueryVersion(mDisplay, &vm_ver, &vm_rev); + printf("XF86VidMode Extension v%i.%i\n", vm_ver, vm_rev); + have_vm=1; + } else + printf("XF86VidMode Extenstion not available.\n"); + + if (have_vm) { + if (vidmodes==NULL) + XF86VidModeGetAllModeLines(mDisplay,screen,&modecount,&vidmodes); + j=0; + modeline_width=vidmodes[0]->hdisplay; + modeline_height=vidmodes[0]->vdisplay; + if ((d_width==0) && (d_height==0)) + { X=image_width; Y=image_height; } + else + { X=d_width; Y=d_height; } + + for (i=1; i<modecount; i++) + if ((vidmodes[i]->hdisplay >= X) && (vidmodes[i]->vdisplay >= Y)) + if ( (vidmodes[i]->hdisplay < modeline_width ) && (vidmodes[i]->vdisplay < modeline_height) ) + { + modeline_width=vidmodes[i]->hdisplay; + modeline_height=vidmodes[i]->vdisplay; + j=i; + } + + printf("XF86VM: Selected video mode %dx%d for image size %dx%d.\n",modeline_width, modeline_height, image_width, image_height); + XF86VidModeLockModeSwitch(mDisplay,screen,0); + XF86VidModeSwitchToMode(mDisplay,screen,vidmodes[j]); + XF86VidModeSwitchToMode(mDisplay,screen,vidmodes[j]); + X=(vo_screenwidth-modeline_width)/2; + Y=(vo_screenheight-modeline_height)/2; + XF86VidModeSetViewPort(mDisplay,screen,X,Y); + } + } +#endif + + if ( fullscreen ) { hint.width=vo_screenwidth; @@ -468,6 +523,16 @@ static uint32_t query_format( uint32_t format ) static void uninit(void) { +#ifdef HAVE_XF86VM + if (vidmodes!=NULL) + { + int screen; screen=DefaultScreen( mDisplay ); + XF86VidModeSwitchToMode(mDisplay,screen,vidmodes[0]); + XF86VidModeSwitchToMode(mDisplay,screen,vidmodes[0]); + free(vidmodes); + } +#endif + printf("vo: uninit!\n"); } |