Mercurial > mplayer.hg
changeset 32:9e66f722790e
the common x11 stuff
author | arpi_esp |
---|---|
date | Sat, 03 Mar 2001 21:47:37 +0000 |
parents | 1fc618eba830 |
children | 2c215d26f54e |
files | libvo/x11_common.c libvo/x11_common.h |
diffstat | 2 files changed, 168 insertions(+), 0 deletions(-) [+] |
line wrap: on
line diff
--- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/libvo/x11_common.c Sat Mar 03 21:47:37 2001 +0000 @@ -0,0 +1,153 @@ +#include <stdio.h> +#include <stdlib.h> +#include <string.h> + +#include <unistd.h> +#include <sys/mman.h> + +#include "config.h" +#include "video_out.h" + +#ifdef X11_FULLSCREEN + +#include <X11/Xlib.h> +#include <X11/Xutil.h> +#include <X11/Xatom.h> + +int vo_depthonscreen=0; +int vo_screenwidth=0; +int vo_screenheight=0; +int vo_dwidth=0; +int vo_dheight=0; + +int vo_init( void ) +{ + int CompletionType = -1; + int mScreen; + int bpp; + char * DisplayName = ":0.0"; + Display * mDisplay; + XImage * mXImage; + Window mRootWin; + static XWindowAttributes attribs; + + if(vo_depthonscreen) return 1; // already called + + if ( getenv( "DISPLAY" ) ) DisplayName=getenv( "DISPLAY" ); + mDisplay=XOpenDisplay( DisplayName ); + if ( !mDisplay ) + { + fprintf( stderr,"vo: couldn't open the X11 display!\n" ); + return 0; + } + mScreen=DefaultScreen( mDisplay ); // Screen ID. + mRootWin=RootWindow( mDisplay,mScreen );// Root window ID. + vo_screenwidth=DisplayWidth( mDisplay,mScreen ); + vo_screenheight=DisplayHeight( mDisplay,mScreen ); + // get color depth: +// XGetWindowAttributes(mydisplay, DefaultRootWindow(mDisplay), &attribs); + XGetWindowAttributes(mDisplay, mRootWin, &attribs); + vo_depthonscreen=attribs.depth; + // get bits/pixel: + mXImage=XGetImage( mDisplay,mRootWin,0,0,1,1,AllPlanes,ZPixmap ); + bpp=mXImage->bits_per_pixel; + XDestroyImage( mXImage ); + if((vo_depthonscreen+7)/8 != (bpp+7)/8) vo_depthonscreen=bpp; // by A'rpi + XCloseDisplay( mDisplay ); + printf("X11 running at %dx%d depth: %d\n",vo_screenwidth,vo_screenheight,vo_depthonscreen); + return 1; +} + +#include "../linux/keycodes.h" +#include "wskeys.h" + +extern void mplayer_put_key(int code); + +void vo_x11_putkey(int key){ + switch ( key ) + { + case wsLeft: mplayer_put_key(KEY_LEFT); break; + case wsRight: mplayer_put_key(KEY_RIGHT); break; + case wsUp: mplayer_put_key(KEY_UP); break; + case wsDown: mplayer_put_key(KEY_DOWN); break; + case wsSpace: mplayer_put_key(' '); break; + case wsEscape: mplayer_put_key(KEY_ESC); break; + case wsEnter: mplayer_put_key(KEY_ENTER); break; + case wsq: + case wsQ: mplayer_put_key('q'); break; + case wsp: + case wsP: mplayer_put_key('p'); break; + case wsMinus: + case wsGrayMinus: mplayer_put_key('-'); break; + case wsPlus: + case wsGrayPlus: mplayer_put_key('+'); break; + } +} + + +// ----- Motif header: ------- + +#define MWM_HINTS_DECORATIONS 2 + +typedef struct +{ + long flags; + long functions; + long decorations; + long input_mode; +} MotifWmHints; + +extern MotifWmHints vo_MotifWmHints; +extern Atom vo_MotifHints; +extern int vo_depthonscreen; +extern int vo_screenwidth; +extern int vo_screenheight; + +static MotifWmHints vo_MotifWmHints; +static Atom vo_MotifHints = None; + +void vo_x11_decoration( Display * vo_Display,Window w,int d ) +{ + vo_MotifHints=XInternAtom( vo_Display,"_MOTIF_WM_HINTS",0 ); + if ( vo_MotifHints != None ) + { + vo_MotifWmHints.flags=2; + vo_MotifWmHints.decorations=d; + XChangeProperty( vo_Display,w,vo_MotifHints,vo_MotifHints,32, + PropModeReplace,(unsigned char *)&vo_MotifWmHints,4 ); + } +} + +int vo_x11_check_events(Display *mydisplay){ + int ret=0; + XEvent Event; + char buf[100]; + KeySym keySym; + XComposeStatus stat; +// unsigned long vo_KeyTable[512]; + + while ( XPending( mydisplay ) ) + { + XNextEvent( mydisplay,&Event ); + switch( Event.type ) + { + case Expose: + ret|=VO_EVENT_EXPOSE; + break; + case ConfigureNotify: + vo_dwidth=Event.xconfigure.width; + vo_dheight=Event.xconfigure.height; + ret|=VO_EVENT_RESIZE; + break; + case KeyPress: + XLookupString( &Event.xkey,buf,sizeof(buf),&keySym,&stat ); + vo_x11_putkey( ( (keySym&0xff00) != 0?( (keySym&0x00ff) + 256 ):( keySym ) ) ); + ret|=VO_EVENT_KEYPRESS; + break; + } + } + + return ret; +} + +#endif
--- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/libvo/x11_common.h Sat Mar 03 21:47:37 2001 +0000 @@ -0,0 +1,15 @@ + +#ifdef X11_FULLSCREEN + +extern int vo_depthonscreen; +extern int vo_screenwidth; +extern int vo_screenheight; +extern int vo_dwidth; +extern int vo_dheight; + +int vo_init( void ); +void vo_x11_decoration( Display * vo_Display,Window w,int d ); +int vo_x11_check_events(Display *mydisplay); + +#endif +