Mercurial > mplayer.hg
diff libvo/video_out.c @ 1:3b5f5d1c5041
Initial revision
author | arpi_esp |
---|---|
date | Sat, 24 Feb 2001 20:28:24 +0000 |
parents | |
children | 7400af1c6d44 |
line wrap: on
line diff
--- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/libvo/video_out.c Sat Feb 24 20:28:24 2001 +0000 @@ -0,0 +1,201 @@ +/* + * video_out.c, + * + * Copyright (C) Aaron Holtzman - June 2000 + * + * mpeg2dec is free software; you can redistribute it and/or modify + * it under the terms of the GNU General Public License as published by + * the Free Software Foundation; either version 2, or (at your option) + * any later version. + * + * mpeg2dec is distributed in the hope that it will be useful, + * but WITHOUT ANY WARRANTY; without even the implied warranty of + * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the + * GNU General Public License for more details. + * + * You should have received a copy of the GNU General Public License + * along with GNU Make; see the file COPYING. If not, write to + * the Free Software Foundation, 675 Mass Ave, Cambridge, MA 02139, USA. + * + */ + +#include <stdio.h> +#include <stdlib.h> +#include <string.h> + +#include <unistd.h> +#include <sys/mman.h> + +#include "config.h" +#include "video_out.h" + +#include "../linux/shmem.h" + +// +// Externally visible list of all vo drivers +// + +extern vo_functions_t video_out_mga; +extern vo_functions_t video_out_xmga; +extern vo_functions_t video_out_x11; +extern vo_functions_t video_out_xv; +extern vo_functions_t video_out_gl; +extern vo_functions_t video_out_sdl; +extern vo_functions_t video_out_3dfx; +extern vo_functions_t video_out_null; +extern vo_functions_t video_out_odivx; +extern vo_functions_t video_out_pgm; +extern vo_functions_t video_out_md5; +extern vo_functions_t video_out_syncfb; + +vo_functions_t* video_out_drivers[] = +{ +#ifdef HAVE_MGA +#ifdef HAVE_X11 + &video_out_xmga, +#endif + &video_out_mga, +#endif +#ifdef HAVE_SYNCFB + &video_out_syncfb, +#endif +#ifdef HAVE_3DFX + &video_out_3dfx, +#endif +#ifdef HAVE_XV + &video_out_xv, +#endif +#ifdef HAVE_X11 + &video_out_x11, +#endif +#ifdef HAVE_GL + &video_out_gl, +#endif +#ifdef HAVE_SDL + &video_out_sdl, +#endif + &video_out_null, + &video_out_odivx, + &video_out_pgm, + &video_out_md5, + NULL +}; + +#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_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" +extern void mplayer_put_key(int code); + +void vo_keyboard( 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_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 ); + } +} + +#include <signal.h> + +int vo_eventhandler_pid=-1; + +void vo_kill_eventhandler(){ + if(vo_eventhandler_pid!=-1) kill(vo_eventhandler_pid,SIGTERM); + +} + +#endif +