const char *gl_version;
const char *gl_extensions;
-qboolean DDActive;
qboolean scr_skipupdate;
static vmode_t modelist[MAX_MODE_LIST];
static int nummodes;
-static vmode_t *pcurrentmode;
+//static vmode_t *pcurrentmode;
static vmode_t badmode;
static DEVMODE gdevmode;
HGLRC baseRC;
HDC maindc;
-glvert_t glv;
-
HWND WINAPI InitializeWindow (HINSTANCE hInstance, int nCmdShow);
viddef_t vid; // global video state
-float gldepthmin, gldepthmax;
-
modestate_t modestate = MS_UNINIT;
void VID_MenuDraw (void);
height = rect.bottom - rect.top;
// Create the DIB window
- mainwindow = CreateWindowEx (ExWindowStyle, "DarkPlaces", "DarkPlacesGL", WindowStyle, rect.left, rect.top, width, height, NULL, NULL, global_hInstance, NULL);
+ mainwindow = CreateWindowEx (ExWindowStyle, gamename, gamename, WindowStyle, rect.left, rect.top, width, height, NULL, NULL, global_hInstance, NULL);
if (!mainwindow)
Sys_Error ("Couldn't create DIB window");
vid.conheight = modelist[modenum].height;
if (vid.conwidth > modelist[modenum].width)
vid.conwidth = modelist[modenum].width;
- vid.width = vid.conwidth;
- vid.height = vid.conheight;
SendMessage (mainwindow, WM_SETICON, (WPARAM)true, (LPARAM)hIcon);
SendMessage (mainwindow, WM_SETICON, (WPARAM)false, (LPARAM)hIcon);
height = rect.bottom - rect.top;
// Create the DIB window
- mainwindow = CreateWindowEx (ExWindowStyle, "DarkPlaces", "DarkPlacesGL", WindowStyle, rect.left, rect.top, width, height, NULL, NULL, global_hInstance, NULL);
+ mainwindow = CreateWindowEx (ExWindowStyle, gamename, gamename, WindowStyle, rect.left, rect.top, width, height, NULL, NULL, global_hInstance, NULL);
if (!mainwindow)
Sys_Error ("Couldn't create DIB window");
vid.conheight = modelist[modenum].height;
if (vid.conwidth > modelist[modenum].width)
vid.conwidth = modelist[modenum].width;
- vid.width = vid.conwidth;
- vid.height = vid.conheight;
// needed because we're not getting WM_MOVE messages fullscreen on NT
window_x = 0;
int VID_SetMode (int modenum)
{
- int original_mode, temp;
- qboolean stat;
+ int original_mode;
+ //int temp;
+ qboolean stat = 0;
MSG msg;
if ((windowed && (modenum != 0)) || (!windowed && (modenum < 1)) || (!windowed && (modenum >= nummodes)))
Sys_Error ("Bad video mode\n");
// so Con_Printfs don't mess us up by forcing vid and snd updates
- temp = scr_disabled_for_loading;
- scr_disabled_for_loading = true;
+// temp = scr_disabled_for_loading;
+// scr_disabled_for_loading = true;
CDAudio_Pause ();
// Set either the fullscreen or windowed mode
if (modelist[modenum].type == MS_WINDOWED)
{
-// if (vid_mouse.value && key_dest == key_game)
+// if (vid_mouse.integer && key_dest == key_game)
// {
// stat = VID_SetWindowedMode(modenum);
// usingmouse = true;
VID_UpdateWindowStatus ();
CDAudio_Resume ();
- scr_disabled_for_loading = temp;
+// scr_disabled_for_loading = temp;
if (!stat)
Sys_Error ("Couldn't set video mode");
if (!msg_suppress_1)
Con_SafePrintf ("Video mode %s initialized.\n", VID_GetModeDescription (vid_modenum));
- vid.recalc_refdef = 1;
+// vid.recalc_refdef = 1;
return true;
}
//====================================
-void VID_CheckMultitexture(void)
-{
- qglMTexCoord2f = NULL;
- qglSelectTexture = NULL;
- gl_mtexable = false;
- // Check to see if multitexture is disabled
- if (COM_CheckParm("-nomtex"))
- {
- Con_Printf("...multitexture disabled\n");
- return;
- }
- // Test for ARB_multitexture
- if (!COM_CheckParm("-SGISmtex") && strstr(gl_extensions, "GL_ARB_multitexture "))
- {
- Con_Printf("...using GL_ARB_multitexture\n");
- qglMTexCoord2f = (void *) wglGetProcAddress("glMultiTexCoord2fARB");
- qglSelectTexture = (void *) wglGetProcAddress("glActiveTextureARB");
- gl_mtexable = true;
- gl_mtex_enum = GL_TEXTURE0_ARB;
- }
- else if (strstr(gl_extensions, "GL_SGIS_multitexture ")) // Test for SGIS_multitexture (if ARB_multitexture not found)
- {
- Con_Printf("...using GL_SGIS_multitexture\n");
- qglMTexCoord2f = (void *) wglGetProcAddress("glMTexCoord2fSGIS");
- qglSelectTexture = (void *) wglGetProcAddress("glSelectTextureSGIS");
- gl_mtexable = true;
- gl_mtex_enum = TEXTURE0_SGIS;
- }
- else
- Con_Printf("...multitexture disabled (not detected)\n");
-}
-
-void VID_CheckCVA(void)
-{
- qglLockArraysEXT = NULL;
- qglUnlockArraysEXT = NULL;
- gl_supportslockarrays = false;
- if (COM_CheckParm("-nocva"))
- {
- Con_Printf("...compiled vertex arrays disabled\n");
- return;
- }
- if (strstr(gl_extensions, "GL_EXT_compiled_vertex_array"))
- {
- Con_Printf("...using compiled vertex arrays\n");
- qglLockArraysEXT = (void *) wglGetProcAddress("glLockArraysEXT");
- qglUnlockArraysEXT = (void *) wglGetProcAddress("glUnlockArraysEXT");
- gl_supportslockarrays = true;
- }
-}
-
/*
=================
-GL_BeginRendering
-
+VID_GetWindowSize
=================
*/
-void GL_BeginRendering (int *x, int *y, int *width, int *height)
+void VID_GetWindowSize (int *x, int *y, int *width, int *height)
{
*x = *y = 0;
*width = WindowRect.right - WindowRect.left;
*height = WindowRect.bottom - WindowRect.top;
-
-// if (!wglMakeCurrent( maindc, baseRC ))
-// Sys_Error ("wglMakeCurrent failed");
-
-// glViewport (*x, *y, *width, *height);
}
-void GL_EndRendering (void)
+void VID_Finish (void)
{
int usemouse;
- if (r_render.value && !scr_skipupdate)
+ if (r_render.integer && !scr_skipupdate)
+ {
+ glFinish();
SwapBuffers(maindc);
+ }
// handle the mouse state when windowed if that's changed
usemouse = false;
- if (vid_mouse.value && key_dest == key_game)
+ if (vid_mouse.integer && key_dest == key_game)
usemouse = true;
if (modestate == MS_FULLDIB)
usemouse = true;
IN_DeactivateMouse ();
}
-void VID_RestoreSystemGamma();
+void VID_RestoreSystemGamma(void);
void VID_Shutdown (void)
{
-byte scantokey[128] =
+qbyte scantokey[128] =
{
// 0 1 2 3 4 5 6 7 8 9 A B C D E F
0 ,27 ,'1' ,'2' ,'3' ,'4' ,'5' ,'6' ,'7' ,'8' ,'9' ,'0' ,'-' ,'=' ,K_BACKSPACE,9 , // 0
};
/*
-byte shiftscantokey[128] =
+qbyte shiftscantokey[128] =
{
// 0 1 2 3 4 5 6 7 8 9 A B C D E F
0 ,27 ,'!' ,'@' ,'#' ,'$' ,'%' ,'^' ,'&' ,'*' ,'(' ,')' ,'_' ,'+' ,K_BACKSPACE,9 , // 0
IN_ClearStates ();
}
-void VID_RestoreGameGamma();
+void VID_RestoreGameGamma(void);
+extern qboolean host_loopactive;
void AppActivate(BOOL fActive, BOOL minimize)
/****************************************************************************
// LordHavoc: from dabb, fix for alt-tab bug in NVidia drivers
MoveWindow(mainwindow,0,0,gdevmode.dmPelsWidth,gdevmode.dmPelsHeight,false);
}
-// else if ((modestate == MS_WINDOWED) && vid_mouse.value && key_dest == key_game)
+// else if ((modestate == MS_WINDOWED) && vid_mouse.integer && key_dest == key_game)
// {
// usingmouse = true;
// IN_ActivateMouse ();
// IN_HideMouse ();
// }
- VID_RestoreGameGamma();
+ if (host_loopactive)
+ VID_RestoreGameGamma();
}
if (!fActive)
vid_wassuspended = true;
}
}
-// else if ((modestate == MS_WINDOWED) && vid_mouse.value)
+// else if ((modestate == MS_WINDOWED) && vid_mouse.integer)
// {
// usingmouse = false;
// IN_DeactivateMouse ();
LONG CDAudio_MessageHandler(HWND hWnd, UINT uMsg, WPARAM wParam, LPARAM lParam);
/* main window procedure */
-LONG WINAPI MainWndProc (
- HWND hWnd,
- UINT uMsg,
- WPARAM wParam,
- LPARAM lParam)
+LONG WINAPI MainWndProc (HWND hWnd, UINT uMsg, WPARAM wParam, LPARAM lParam)
{
LONG lRet = 1;
int fActive, fMinimized, temp;
wc.hCursor = LoadCursor (NULL,IDC_ARROW);
wc.hbrBackground = NULL;
wc.lpszMenuName = 0;
- wc.lpszClassName = "DarkPlaces";
+ wc.lpszClassName = gamename;
if (!RegisterClass (&wc) )
Sys_Error ("Couldn't register window class");
Con_SafePrintf ("No fullscreen DIB modes found\n");
}
-static int grabsysgamma = true;
+//static int grabsysgamma = true;
WORD systemgammaramps[3][256], currentgammaramps[3][256];
int VID_SetGamma(float prescale, float gamma, float scale, float base)
return i; // return success or failure
}
-void VID_RestoreGameGamma()
+void VID_RestoreGameGamma(void)
{
VID_UpdateGamma(true);
}
-void VID_GetSystemGamma()
+void VID_GetSystemGamma(void)
{
HDC hdc;
hdc = GetDC (NULL);
ReleaseDC (NULL, hdc);
}
-void VID_RestoreSystemGamma()
+void VID_RestoreSystemGamma(void)
{
HDC hdc;
hdc = GetDC (NULL);
VID_Init
===================
*/
-void VID_Init ()
+void VID_Init (void)
{
int i;
// int existingmode;
- int basenummodes, width, height, bpp, findbpp, done;
+ int basenummodes, width, height = 0, bpp, findbpp, done;
HDC hdc;
DEVMODE devmode;
extern void M_Print (int cx, int cy, char *str);
extern void M_PrintWhite (int cx, int cy, char *str);
extern void M_DrawCharacter (int cx, int line, int num);
-extern void M_DrawPic (int x, int y, qpic_t *pic);
+extern void M_DrawPic (int x, int y, char *picname);
-static int vid_line, vid_wmodes;
+static int vid_wmodes;
typedef struct
{
*/
void VID_MenuDraw (void)
{
- qpic_t *p;
- char *ptr;
- int lnummodes, i, k, column, row;
- vmode_t *pv;
+ cachepic_t *p;
+ char *ptr;
+ int lnummodes, i, k, column, row;
+ vmode_t *pv;
p = Draw_CachePic ("gfx/vidmodes.lmp");
- M_DrawPic ( (320-p->width)/2, 4, p);
+ M_DrawPic ( (320-p->width)/2, 4, "gfx/vidmodes.lmp");
vid_wmodes = 0;
lnummodes = VID_NumModes ();
-
+
for (i=1 ; (i<lnummodes) && (vid_wmodes < MAX_MODEDESCS) ; i++)
{
ptr = VID_GetModeDescription (i);
}
}
- M_Print (3*8, 36 + MODE_AREA_HEIGHT * 8 + 8*2,
- "Video modes must be set from the");
- M_Print (3*8, 36 + MODE_AREA_HEIGHT * 8 + 8*3,
- "command line with -width <width>");
- M_Print (3*8, 36 + MODE_AREA_HEIGHT * 8 + 8*4,
- "and -bpp <bits-per-pixel>");
- M_Print (3*8, 36 + MODE_AREA_HEIGHT * 8 + 8*6,
- "Select windowed mode with -window");
+ M_Print (3*8, 36 + MODE_AREA_HEIGHT * 8 + 8*2, "Video modes must be set from the");
+ M_Print (3*8, 36 + MODE_AREA_HEIGHT * 8 + 8*3, "command line with -width <width>");
+ M_Print (3*8, 36 + MODE_AREA_HEIGHT * 8 + 8*4, "and -bpp <bits-per-pixel>");
+ M_Print (3*8, 36 + MODE_AREA_HEIGHT * 8 + 8*6, "Select windowed mode with -window");
}