aboutsummaryrefslogtreecommitdiffhomepage
diff options
context:
space:
mode:
authorGravatar mgraffam <mgraffam@b3059339-0415-0410-9bf9-f77b7e298cf2>2001-03-24 21:31:37 +0000
committerGravatar mgraffam <mgraffam@b3059339-0415-0410-9bf9-f77b7e298cf2>2001-03-24 21:31:37 +0000
commitd1b372c1a2d1d46be7c25d93d2cf801c16da6426 (patch)
treecb5014f82e38e5b51e87f7dd5ed47bed6429e82e
parent752de843ff036132da06752d753dd12b0ad5e529 (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.c65
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");
}