/* vid_glx.c OpenGL GLX video driver Copyright (C) 1996-1997 Id Software, Inc. Copyright (C) 2000 Marcus Sundberg [mackan@stacken.kth.se] This program 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 of the License, or (at your option) any later version. This program 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 this program; if not, write to: Free Software Foundation, Inc. 59 Temple Place - Suite 330 Boston, MA 02111-1307, USA $Id$ */ #ifdef HAVE_CONFIG_H # include "config.h" #endif #ifdef HAVE_STRING_H # include #endif #ifdef HAVE_STRINGS_H # include #endif #include #include #include #ifdef HAVE_DGA # include #endif #include "QF/compat.h" #include "QF/console.h" #include "context_x11.h" #include "glquake.h" #include "host.h" #include "QF/input.h" #include "QF/qargs.h" #include "QF/qendian.h" #include "QF/quakefs.h" #include "sbar.h" #include "QF/va.h" #define WARP_WIDTH 320 #define WARP_HEIGHT 200 static qboolean vid_initialized = false; static GLXContext ctx = NULL; extern void GL_Init_Common (void); extern void VID_Init8bitPalette (void); /*-----------------------------------------------------------------------*/ const char *gl_vendor; const char *gl_renderer; const char *gl_version; const char *gl_extensions; void VID_Shutdown (void) { if (!vid_initialized) return; Con_Printf ("VID_Shutdown\n"); X11_RestoreVidMode (); X11_CloseDisplay (); } #if 0 static void signal_handler (int sig) { printf ("Received signal %d, exiting...\n", sig); Sys_Quit (); exit (sig); } static void InitSig (void) { signal (SIGHUP, signal_handler); signal (SIGINT, signal_handler); signal (SIGQUIT, signal_handler); signal (SIGILL, signal_handler); signal (SIGTRAP, signal_handler); signal (SIGIOT, signal_handler); signal (SIGBUS, signal_handler); /* signal (SIGFPE, signal_handler); */ signal (SIGSEGV, signal_handler); signal (SIGTERM, signal_handler); } #endif /* GL_Init */ void GL_Init (void) { GL_Init_Common (); } void GL_EndRendering (void) { glFlush (); glXSwapBuffers (x_disp, x_win); Sbar_Changed (); } void VID_Init (unsigned char *palette) { int i; int attrib[] = { GLX_RGBA, GLX_RED_SIZE, 1, GLX_GREEN_SIZE, 1, GLX_BLUE_SIZE, 1, GLX_DOUBLEBUFFER, GLX_DEPTH_SIZE, 1, None }; VID_GetWindowSize (640, 480); Con_CheckResize (); // Now that we have a window size, fix console vid.maxwarpwidth = WARP_WIDTH; vid.maxwarpheight = WARP_HEIGHT; vid.colormap = host_colormap; vid.fullbright = 256 - LittleLong (*((int *) vid.colormap + 2048)); /* Interpret command-line params */ /* Set vid parameters */ if ((i = COM_CheckParm ("-conwidth"))) vid.conwidth = atoi (com_argv[i + 1]); else vid.conwidth = scr_width; vid.conwidth &= 0xfff8; // make it a multiple of eight vid.conwidth = max (vid.conwidth, 320); // pick a conheight that matches with correct aspect vid.conheight = vid.conwidth * 3 / 4; if ((i = COM_CheckParm ("-conheight"))) // conheight no smaller than // 200px vid.conheight = atoi (com_argv[i + 1]); vid.conheight = max (vid.conheight, 200); X11_OpenDisplay (); x_visinfo = glXChooseVisual (x_disp, x_screen, attrib); if (!x_visinfo) { fprintf (stderr, "Error couldn't get an RGB, Double-buffered, Depth visual\n"); exit (1); } x_vis = x_visinfo->visual; X11_SetVidMode (scr_width, scr_height); X11_CreateWindow (scr_width, scr_height); /* Invisible cursor */ X11_CreateNullCursor (); X11_GrabKeyboard (); XSync (x_disp, 0); ctx = glXCreateContext (x_disp, x_visinfo, NULL, True); glXMakeCurrent (x_disp, x_win, ctx); vid.height = vid.conheight = min (vid.conheight, scr_height); vid.width = vid.conwidth = min (vid.conwidth, scr_width); vid.aspect = ((float) vid.height / (float) vid.width) * (320.0 / 240.0); vid.numpages = 2; // InitSig (); // trap evil signals GL_Init (); GL_CheckBrightness (palette); VID_InitGamma (palette); VID_SetPalette (palette); // Check for 8-bit extension and initialize if present VID_Init8bitPalette (); Con_Printf ("Video mode %dx%d initialized.\n", scr_width, scr_height); vid_initialized = true; vid.recalc_refdef = 1; // force a surface cache flush } void VID_Init_Cvars () { X11_Init_Cvars (); } void VID_SetCaption (char *text) { if (text && *text) { char *temp = strdup (text); X11_SetCaption (va ("%s %s: %s", PROGRAM, VERSION, temp)); free (temp); } else { X11_SetCaption (va ("%s %s", PROGRAM, VERSION)); } } double VID_GetGamma (void) { return (double) X11_GetGamma (); } qboolean VID_SetGamma (double gamma) { return X11_SetGamma (gamma); } void VID_UpdateGamma (cvar_t *vid_gamma) { if (vid_gamma->flags & CVAR_ROM) // System gamma unavailable return; Cvar_SetValue (vid_gamma, bound (0.1, vid_gamma->value, 9.9)); X11_SetGamma (vid_gamma->value); }