Remove vid_mode. VID_GetModeString now returns only supported modes from SDL2

This commit is contained in:
Alibek Omarov 2018-04-29 09:21:23 +03:00
parent c8b83385df
commit 3f2a8f7704
9 changed files with 266 additions and 286 deletions

View File

@ -574,7 +574,6 @@ typedef struct
qboolean softwareGammaUpdate; qboolean softwareGammaUpdate;
int prev_width; int prev_width;
int prev_height; int prev_height;
int prev_mode;
} glconfig_t; } glconfig_t;
typedef struct typedef struct
@ -667,12 +666,10 @@ extern convar_t *vid_displayfrequency;
extern convar_t *vid_fullscreen; extern convar_t *vid_fullscreen;
extern convar_t *vid_brightness; extern convar_t *vid_brightness;
extern convar_t *vid_gamma; extern convar_t *vid_gamma;
extern convar_t *vid_mode;
extern convar_t *vid_highdpi; extern convar_t *vid_highdpi;
extern convar_t *window_xpos; extern convar_t *window_xpos;
extern convar_t *window_ypos; extern convar_t *window_ypos;
extern convar_t *scr_width;
extern convar_t *scr_height; extern convar_t *scr_height;
#endif//GL_LOCAL_H #endif//GL_LOCAL_H

View File

@ -1697,7 +1697,7 @@ int IN_TouchEvent( touchEventType type, int fingerID, float x, float y, float dx
Key_Event( K_MOUSE1, true ); Key_Event( K_MOUSE1, true );
if( type == event_up ) if( type == event_up )
Key_Event( K_MOUSE1, false ); Key_Event( K_MOUSE1, false );
Android_AddMove( dx * scr_width->value, dy * scr_height->value ); Android_AddMove( dx * (float)glState.width, dy * glState.height );
#endif #endif
return 0; return 0;
} }

View File

@ -24,17 +24,17 @@ GNU General Public License for more details.
#include "library.h" #include "library.h"
#include "keydefs.h" #include "keydefs.h"
#include "gl_local.h" #include "gl_local.h"
#ifdef XASH_SDL
#include <SDL_events.h>
static SDL_Cursor* s_pDefaultCursor[20];
#endif
int g_textures[VGUI_MAX_TEXTURES]; int g_textures[VGUI_MAX_TEXTURES];
int g_textureId = 0; int g_textureId = 0;
int g_iBoundTexture; int g_iBoundTexture;
static enum VGUI_KeyCode s_pVirtualKeyTrans[256]; static enum VGUI_KeyCode s_pVirtualKeyTrans[256];
static enum VGUI_DefaultCursor s_currentCursor; static enum VGUI_DefaultCursor s_currentCursor;
#ifdef XASH_SDL static HINSTANCE s_pVGuiSupport; // vgui_support library
#include <SDL_events.h>
static SDL_Cursor* s_pDefaultCursor[20];
#endif
static void *s_pVGuiSupport; // vgui_support library
static convar_t *vgui_utf8 = NULL; static convar_t *vgui_utf8 = NULL;
void VGUI_DrawInit( void ); void VGUI_DrawInit( void );

View File

@ -41,8 +41,6 @@ convar_t *gl_test;
convar_t *gl_msaa; convar_t *gl_msaa;
convar_t *gl_stencilbits; convar_t *gl_stencilbits;
convar_t *scr_width;
convar_t *scr_height;
convar_t *window_xpos; convar_t *window_xpos;
convar_t *window_ypos; convar_t *window_ypos;
convar_t *r_speeds; convar_t *r_speeds;
@ -68,7 +66,6 @@ convar_t *vid_displayfrequency;
convar_t *vid_fullscreen; convar_t *vid_fullscreen;
convar_t *vid_brightness; convar_t *vid_brightness;
convar_t *vid_gamma; convar_t *vid_gamma;
convar_t *vid_mode;
convar_t *vid_highdpi; convar_t *vid_highdpi;
byte *r_temppool; byte *r_temppool;
@ -236,39 +233,19 @@ R_SaveVideoMode
*/ */
void R_SaveVideoMode( int w, int h ) void R_SaveVideoMode( int w, int h )
{ {
host.window_center_x = glState.width / 2;
host.window_center_y = glState.height / 2;
glState.width = w; glState.width = w;
glState.height = h; glState.height = h;
Cvar_FullSet( "width", va( "%i", w ), FCVAR_READ_ONLY | FCVAR_RENDERINFO ); Cvar_SetValue( "width", w );
Cvar_FullSet( "height", va( "%i", h ), FCVAR_READ_ONLY | FCVAR_RENDERINFO ); Cvar_SetValue( "height", h );
if( vid_mode->value >= 0 && vid_mode->value <= R_MaxVideoModes() ) // check for 4:3 or 5:4
glState.wideScreen = R_GetVideoMode( vid_mode->value ).wideScreen; if( w * 3 != h * 4 && w * 4 != h * 5 )
glState.wideScreen = true;
MsgDev( D_NOTE, "Set: [%dx%d]\n", w, h ); else glState.wideScreen = false;
}
/*
=================
R_DescribeVIDMode
=================
*/
qboolean R_DescribeVIDMode( int width, int height )
{
int i;
for( i = 0; i < R_MaxVideoModes(); i++ )
{
vidmode_t vidmode = R_GetVideoMode( i );
if( vidmode.width == width && vidmode.height == height )
{
// found specified mode
Cvar_SetValue( "vid_mode", i );
return true;
}
}
return false;
} }
/* /*
@ -302,15 +279,15 @@ void VID_CheckChanges( void )
if( host.renderinfo_changed ) if( host.renderinfo_changed )
{ {
if( !VID_SetMode( )) if( VID_SetMode( ))
{ {
Sys_Error( "Can't re-initialize video subsystem\n" ); SCR_VidInit(); // tell the client.dll what vid_mode has changed
} }
else else
{ {
host.renderinfo_changed = false; Sys_Error( "Can't re-initialize video subsystem\n" );
SCR_VidInit(); // tell the client.dll what vid_mode has changed
} }
host.renderinfo_changed = false;
} }
} }
@ -397,13 +374,43 @@ void R_RenderInfo_f( void )
} }
Con_Printf( "\n" ); Con_Printf( "\n" );
Con_Printf( "MODE: %s\n", R_GetVideoMode(vid_mode->value).desc ); Con_Printf( "MODE: %ix%i\n", glState.width, glState.height );
Con_Printf( "\n" ); Con_Printf( "\n" );
Con_Printf( "VERTICAL SYNC: %s\n", gl_vsync->value ? "enabled" : "disabled" ); Con_Printf( "VERTICAL SYNC: %s\n", gl_vsync->value ? "enabled" : "disabled" );
Con_Printf( "Color %d bits, Alpha %d bits, Depth %d bits, Stencil %d bits\n", glConfig.color_bits, Con_Printf( "Color %d bits, Alpha %d bits, Depth %d bits, Stencil %d bits\n", glConfig.color_bits,
glConfig.alpha_bits, glConfig.depth_bits, glConfig.stencil_bits ); glConfig.alpha_bits, glConfig.depth_bits, glConfig.stencil_bits );
} }
static void VID_Mode_f( void )
{
int w, h;
switch( Cmd_Argc() )
{
case 2:
{
vidmode_t vidmode;
vidmode = R_GetVideoMode( Q_atoi( Cmd_Argv( 1 )) );
w = vidmode.width;
h = vidmode.height;
break;
}
case 3:
{
w = Q_atoi( Cmd_Argv( 1 ));
h = Q_atoi( Cmd_Argv( 2 ));
break;
}
default:
Msg( "Usage: vid_mode <modenum>|<width height>\n" );
return;
}
R_ChangeDisplaySettings( w, h, Cvar_VariableInteger( "fullscreen" ) );
}
//======================================================================= //=======================================================================
/* /*
@ -414,8 +421,8 @@ GL_InitCommands
void GL_InitCommands( void ) void GL_InitCommands( void )
{ {
// system screen width and height (don't suppose for change from console at all) // system screen width and height (don't suppose for change from console at all)
scr_width = Cvar_Get( "width", "640", FCVAR_RENDERINFO, "screen width" ); Cvar_Get( "width", "0", FCVAR_RENDERINFO|FCVAR_VIDRESTART, "screen width" );
scr_height = Cvar_Get( "height", "480", FCVAR_RENDERINFO, "screen height" ); Cvar_Get( "height", "0", FCVAR_RENDERINFO|FCVAR_VIDRESTART, "screen height" );
r_speeds = Cvar_Get( "r_speeds", "0", FCVAR_ARCHIVE, "shows renderer speeds" ); r_speeds = Cvar_Get( "r_speeds", "0", FCVAR_ARCHIVE, "shows renderer speeds" );
r_fullbright = Cvar_Get( "r_fullbright", "0", FCVAR_CHEAT, "disable lightmaps, get fullbright for entities" ); r_fullbright = Cvar_Get( "r_fullbright", "0", FCVAR_CHEAT, "disable lightmaps, get fullbright for entities" );
r_norefresh = Cvar_Get( "r_norefresh", "0", 0, "disable 3D rendering (use with caution)" ); r_norefresh = Cvar_Get( "r_norefresh", "0", 0, "disable 3D rendering (use with caution)" );
@ -461,14 +468,17 @@ void GL_InitCommands( void )
SetBits( gl_vsync->flags, FCVAR_CHANGED ); SetBits( gl_vsync->flags, FCVAR_CHANGED );
vid_gamma = Cvar_Get( "gamma", "2.5", FCVAR_ARCHIVE, "gamma amount" ); vid_gamma = Cvar_Get( "gamma", "2.5", FCVAR_ARCHIVE, "gamma amount" );
vid_brightness = Cvar_Get( "brightness", "0.0", FCVAR_ARCHIVE, "brighntess factor" ); vid_brightness = Cvar_Get( "brightness", "0.0", FCVAR_ARCHIVE, "brightness factor" );
vid_mode = Cvar_Get( "vid_mode", "-1", FCVAR_RENDERINFO|FCVAR_VIDRESTART, "display resolution mode" );
vid_fullscreen = Cvar_Get( "fullscreen", "0", FCVAR_RENDERINFO|FCVAR_VIDRESTART, "enable fullscreen mode" ); vid_fullscreen = Cvar_Get( "fullscreen", "0", FCVAR_RENDERINFO|FCVAR_VIDRESTART, "enable fullscreen mode" );
vid_displayfrequency = Cvar_Get ( "vid_displayfrequency", "0", FCVAR_RENDERINFO|FCVAR_VIDRESTART, "fullscreen refresh rate" ); vid_displayfrequency = Cvar_Get ( "vid_displayfrequency", "0", FCVAR_RENDERINFO|FCVAR_VIDRESTART, "fullscreen refresh rate" );
vid_highdpi = Cvar_Get( "vid_highdpi", "1", FCVAR_RENDERINFO|FCVAR_VIDRESTART, "Enable High-DPI mode" ); vid_highdpi = Cvar_Get( "vid_highdpi", "1", FCVAR_RENDERINFO|FCVAR_VIDRESTART, "enable High-DPI mode" );
Cmd_AddCommand( "r_info", R_RenderInfo_f, "display renderer info" ); Cmd_AddCommand( "r_info", R_RenderInfo_f, "display renderer info" );
// a1ba: planned to be named vid_mode for compability
// but supported mode list is filled by backends, so numbers are not portable any more
Cmd_AddCommand( "vid_setmode", VID_Mode_f, "display video mode" );
// give initial OpenGL configuration // give initial OpenGL configuration
host.apply_opengl_config = true; host.apply_opengl_config = true;
Cbuf_AddText( "exec opengl.cfg\n" ); Cbuf_AddText( "exec opengl.cfg\n" );
@ -490,72 +500,9 @@ void GL_RemoveCommands( void )
Cmd_RemoveCommand( "r_info"); Cmd_RemoveCommand( "r_info");
} }
#ifdef WIN32
typedef enum _XASH_DPI_AWARENESS
{
XASH_DPI_UNAWARE = 0,
XASH_SYSTEM_DPI_AWARE = 1,
XASH_PER_MONITOR_DPI_AWARE = 2
} XASH_DPI_AWARENESS;
void WIN_SetDPIAwareness( void )
{
HMODULE hModule;
HRESULT ( __stdcall *pSetProcessDpiAwareness )( XASH_DPI_AWARENESS );
BOOL ( __stdcall *pSetProcessDPIAware )( void );
BOOL bSuccess = FALSE;
if( ( hModule = LoadLibrary( "shcore.dll" ) ) )
{
if( ( pSetProcessDpiAwareness = (void*)GetProcAddress( hModule, "SetProcessDpiAwareness" ) ) )
{
// I hope SDL don't handle WM_DPICHANGED message
HRESULT hResult = pSetProcessDpiAwareness( XASH_SYSTEM_DPI_AWARE );
if( hResult == S_OK )
{
MsgDev( D_NOTE, "SetDPIAwareness: Success\n" );
bSuccess = TRUE;
}
else if( hResult = E_INVALIDARG ) MsgDev( D_NOTE, "SetDPIAwareness: Invalid argument\n" );
else if( hResult == E_ACCESSDENIED ) MsgDev( D_NOTE, "SetDPIAwareness: Access Denied\n" );
}
else MsgDev( D_NOTE, "SetDPIAwareness: Can't get SetProcessDpiAwareness\n" );
FreeLibrary( hModule );
}
else MsgDev( D_NOTE, "SetDPIAwareness: Can't load shcore.dll\n" );
if( !bSuccess )
{
MsgDev( D_NOTE, "SetDPIAwareness: Trying SetProcessDPIAware...\n" );
if( ( hModule = LoadLibrary( "user32.dll" ) ) )
{
if( ( pSetProcessDPIAware = ( void* )GetProcAddress( hModule, "SetProcessDPIAware" ) ) )
{
// I hope SDL don't handle WM_DPICHANGED message
BOOL hResult = pSetProcessDPIAware();
if( hResult )
{
MsgDev( D_NOTE, "SetDPIAwareness: Success\n" );
bSuccess = TRUE;
}
else MsgDev( D_NOTE, "SetDPIAwareness: fail\n" );
}
else MsgDev( D_NOTE, "SetDPIAwareness: Can't get SetProcessDPIAware\n" );
FreeLibrary( hModule );
}
else MsgDev( D_NOTE, "SetDPIAwareness: Can't load user32.dll\n" );
}
}
#endif
static void SetWidthAndHeightFromCommandLine() static void SetWidthAndHeightFromCommandLine()
{ {
int width; int width, height;
int height;
Sys_GetIntFromCmdLine( "-width", &width ); Sys_GetIntFromCmdLine( "-width", &width );
Sys_GetIntFromCmdLine( "-height", &height ); Sys_GetIntFromCmdLine( "-height", &height );
@ -566,9 +513,7 @@ static void SetWidthAndHeightFromCommandLine()
return; return;
} }
Cvar_SetValue( "vid_mode", VID_NOMODE ); R_SaveVideoMode( width, height );
Cvar_SetValue( "width", width );
Cvar_SetValue( "height", height );
} }
static void SetFullscreenModeFromCommandLine( ) static void SetFullscreenModeFromCommandLine( )
@ -605,10 +550,6 @@ qboolean R_Init( void )
GL_SetDefaultState(); GL_SetDefaultState();
#ifdef WIN32
WIN_SetDPIAwareness( );
#endif
// create the window and set up the context // create the window and set up the context
if( !R_Init_OpenGL( )) if( !R_Init_OpenGL( ))
{ {

View File

@ -7,7 +7,6 @@ typedef struct vidmode_s
const char *desc; const char *desc;
int width; int width;
int height; int height;
qboolean wideScreen;
} vidmode_t; } vidmode_t;
typedef enum typedef enum
@ -18,12 +17,9 @@ typedef enum
rserr_unknown rserr_unknown
} rserr_t; } rserr_t;
typedef enum // minimal recommended resolution
{ #define VID_MIN_WIDTH 640
VID_NOMODE = -2, #define VID_MIN_HEIGHT 480
VID_AUTOMODE = -1,
VID_DEFAULTMODE = 3 // 640x480
} vidmode_e;
// //
// vid_common.c // vid_common.c
@ -38,7 +34,6 @@ int GL_MaxTextureUnits( void );
qboolean R_Init( void ); qboolean R_Init( void );
void R_Shutdown( void ); void R_Shutdown( void );
const char *VID_GetModeString( int vid_mode ); const char *VID_GetModeString( int vid_mode );
qboolean R_DescribeVIDMode( int width, int height );
void R_SaveVideoMode( int w, int h ); void R_SaveVideoMode( int w, int h );
void VID_StartupGamma( void ); void VID_StartupGamma( void );
void GL_CheckExtension( const char *name, const dllfunc_t *funcs, const char *cvarname, int r_ext ); void GL_CheckExtension( const char *name, const dllfunc_t *funcs, const char *cvarname, int r_ext );

View File

@ -230,10 +230,10 @@ static void SDLash_EventFilter( SDL_Event *event )
#ifdef TOUCHEMU #ifdef TOUCHEMU
if( mdown ) if( mdown )
IN_TouchEvent( event_motion, 0, IN_TouchEvent( event_motion, 0,
event->motion.x/scr_width->value, event->motion.x/(float)glState.width,
event->motion.y/scr_height->value, event->motion.y/(float)glState.height,
event->motion.xrel/scr_width->value, event->motion.xrel/(float)glState.width,
event->motion.yrel/scr_height->value ); event->motion.yrel/(float)glState.height );
SDL_ShowCursor( true ); SDL_ShowCursor( true );
#endif #endif
break; break;
@ -243,8 +243,8 @@ static void SDLash_EventFilter( SDL_Event *event )
#ifdef TOUCHEMU #ifdef TOUCHEMU
mdown = event->button.state != SDL_RELEASED; mdown = event->button.state != SDL_RELEASED;
IN_TouchEvent( event_down, 0, IN_TouchEvent( event_down, 0,
event->button.x/scr_width->value, event->button.x/(float)glState.width,
event->button.y/scr_height->value, 0, 0); event->button.y/(float)glState.height, 0, 0);
#else #else
SDLash_MouseEvent( event->button ); SDLash_MouseEvent( event->button );
#endif #endif
@ -261,14 +261,13 @@ static void SDLash_EventFilter( SDL_Event *event )
SDLash_KeyEvent( event->key ); SDLash_KeyEvent( event->key );
break; break;
/* Touch events */ /* Touch events */
case SDL_FINGERDOWN: case SDL_FINGERDOWN:
case SDL_FINGERUP: case SDL_FINGERUP:
case SDL_FINGERMOTION: case SDL_FINGERMOTION:
{ {
touchEventType type;
static int scale = 0; static int scale = 0;
touchEventType type;
float x, y, dx, dy; float x, y, dx, dy;
if( event->type == SDL_FINGERDOWN ) if( event->type == SDL_FINGERDOWN )
@ -456,7 +455,6 @@ static void SDLash_EventFilter( SDL_Event *event )
break; break;
case SDL_WINDOWEVENT_RESIZED: case SDL_WINDOWEVENT_RESIZED:
if( vid_fullscreen->value ) break; if( vid_fullscreen->value ) break;
Cvar_SetValue( "vid_mode", VID_NOMODE ); // no mode
R_ChangeDisplaySettingsFast( event->window.data1, R_ChangeDisplaySettingsFast( event->window.data1,
event->window.data2 ); event->window.data2 );
break; break;
@ -464,7 +462,6 @@ static void SDLash_EventFilter( SDL_Event *event )
{ {
int w, h; int w, h;
if( vid_fullscreen->value ) break; if( vid_fullscreen->value ) break;
Cvar_SetValue( "vid_mode", VID_NOMODE ); // no mode
SDL_GL_GetDrawableSize( host.hWnd, &w, &h ); SDL_GL_GetDrawableSize( host.hWnd, &w, &h );
R_ChangeDisplaySettingsFast( w, h ); R_ChangeDisplaySettingsFast( w, h );

View File

@ -20,37 +20,8 @@ GNU General Public License for more details.
#include "vid_common.h" #include "vid_common.h"
#include <SDL.h> #include <SDL.h>
#define num_vidmodes ARRAYSIZE( vidmode ) static vidmode_t *vidmodes = NULL;
static int num_vidmodes = 0;
vidmode_t vidmode[] =
{
{ "640 x 480", 640, 480, false },
{ "800 x 600", 800, 600, false },
{ "960 x 720", 960, 720, false },
{ "1024 x 768", 1024, 768, false },
{ "1152 x 864", 1152, 864, false },
{ "1280 x 800", 1280, 800, false },
{ "1280 x 960", 1280, 960, false },
{ "1280 x 1024", 1280, 1024, false },
{ "1600 x 1200", 1600, 1200, false },
{ "2048 x 1536", 2048, 1536, false },
{ "800 x 480 (wide)", 800, 480, true },
{ "856 x 480 (wide)", 856, 480, true },
{ "960 x 540 (wide)", 960, 540, true },
{ "1024 x 576 (wide)", 1024, 576, true },
{ "1024 x 600 (wide)", 1024, 600, true },
{ "1280 x 720 (wide)", 1280, 720, true },
{ "1360 x 768 (wide)", 1360, 768, true },
{ "1366 x 768 (wide)", 1366, 768, true },
{ "1440 x 900 (wide)", 1440, 900, true },
{ "1680 x 1050 (wide)", 1680, 1050, true },
{ "1920 x 1080 (wide)", 1920, 1080, true },
{ "1920 x 1200 (wide)", 1920, 1200, true },
{ "2560 x 1440 (wide)", 2560, 1440, true },
{ "2560 x 1600 (wide)", 2560, 1600, true },
{ "1600 x 900 (wide)", 1600, 900, true },
{ "3840 x 2160 (wide)", 3840, 2160, true },
};
static dllfunc_t opengl_110funcs[] = static dllfunc_t opengl_110funcs[] =
{ {
@ -225,6 +196,145 @@ static dllfunc_t texturecompressionfuncs[] =
static void GL_SetupAttributes( void ); static void GL_SetupAttributes( void );
int R_MaxVideoModes( void )
{
return num_vidmodes;
}
vidmode_t R_GetVideoMode( int num )
{
static vidmode_t error = { NULL };
if( !vidmodes || num < 0 || num > R_MaxVideoModes() )
{
error.width = glState.width;
error.height = glState.height;
return error;
}
return vidmodes[num];
}
static void R_InitVideoModes( void )
{
int displayIndex = 0; // TODO: handle multiple displays somehow
int i, modes;
modes = SDL_GetNumDisplayModes( displayIndex );
if( !modes )
return;
vidmodes = Mem_Alloc( host.mempool, modes * sizeof( vidmode_t ) );
for( i = 0; i < modes; i++ )
{
int j;
qboolean skip = false;
SDL_DisplayMode mode;
if( SDL_GetDisplayMode( displayIndex, i, &mode ) )
{
Msg( "SDL_GetDisplayMode: %s\n", SDL_GetError() );
continue;
}
if( mode.w < VID_MIN_WIDTH || mode.h < VID_MIN_HEIGHT )
continue;
for( j = 0; j < num_vidmodes; j++ )
{
if( mode.w == vidmodes[j].width &&
mode.h == vidmodes[j].height )
{
skip = true;
break;
}
}
if( j != num_vidmodes )
continue;
vidmodes[num_vidmodes].width = mode.w;
vidmodes[num_vidmodes].height = mode.h;
vidmodes[num_vidmodes].desc = copystring( va( "%ix%i", mode.w, mode.h ));
num_vidmodes++;
}
}
static void R_FreeVideoModes( void )
{
int i;
for( i = 0; i < num_vidmodes; i++ )
Mem_Free( (char*)vidmodes[i].desc );
Mem_Free( vidmodes );
vidmodes = NULL;
}
#ifdef WIN32
typedef enum _XASH_DPI_AWARENESS
{
XASH_DPI_UNAWARE = 0,
XASH_SYSTEM_DPI_AWARE = 1,
XASH_PER_MONITOR_DPI_AWARE = 2
} XASH_DPI_AWARENESS;
static void WIN_SetDPIAwareness( void )
{
HMODULE hModule;
HRESULT ( __stdcall *pSetProcessDpiAwareness )( XASH_DPI_AWARENESS );
BOOL ( __stdcall *pSetProcessDPIAware )( void );
BOOL bSuccess = FALSE;
if( ( hModule = LoadLibrary( "shcore.dll" ) ) )
{
if( ( pSetProcessDpiAwareness = (void*)GetProcAddress( hModule, "SetProcessDpiAwareness" ) ) )
{
// I hope SDL don't handle WM_DPICHANGED message
HRESULT hResult = pSetProcessDpiAwareness( XASH_SYSTEM_DPI_AWARE );
if( hResult == S_OK )
{
MsgDev( D_NOTE, "SetDPIAwareness: Success\n" );
bSuccess = TRUE;
}
else if( hResult = E_INVALIDARG ) MsgDev( D_NOTE, "SetDPIAwareness: Invalid argument\n" );
else if( hResult == E_ACCESSDENIED ) MsgDev( D_NOTE, "SetDPIAwareness: Access Denied\n" );
}
else MsgDev( D_NOTE, "SetDPIAwareness: Can't get SetProcessDpiAwareness\n" );
FreeLibrary( hModule );
}
else MsgDev( D_NOTE, "SetDPIAwareness: Can't load shcore.dll\n" );
if( !bSuccess )
{
MsgDev( D_NOTE, "SetDPIAwareness: Trying SetProcessDPIAware...\n" );
if( ( hModule = LoadLibrary( "user32.dll" ) ) )
{
if( ( pSetProcessDPIAware = ( void* )GetProcAddress( hModule, "SetProcessDPIAware" ) ) )
{
// I hope SDL don't handle WM_DPICHANGED message
BOOL hResult = pSetProcessDPIAware();
if( hResult )
{
MsgDev( D_NOTE, "SetDPIAwareness: Success\n" );
bSuccess = TRUE;
}
else MsgDev( D_NOTE, "SetDPIAwareness: fail\n" );
}
else MsgDev( D_NOTE, "SetDPIAwareness: Can't get SetProcessDPIAware\n" );
FreeLibrary( hModule );
}
else MsgDev( D_NOTE, "SetDPIAwareness: Can't load user32.dll\n" );
}
}
#endif
/* /*
======================== ========================
DebugCallback DebugCallback
@ -377,7 +487,6 @@ qboolean GL_DeleteContext( void )
return false; return false;
} }
static qboolean recreate = false;
qboolean VID_SetScreenResolution( int width, int height ) qboolean VID_SetScreenResolution( int width, int height )
{ {
SDL_DisplayMode want, got; SDL_DisplayMode want, got;
@ -397,21 +506,12 @@ qboolean VID_SetScreenResolution( int width, int height )
MsgDev(D_NOTE, "Got closest display mode: %ix%i@%i\n", got.w, got.h, got.refresh_rate); MsgDev(D_NOTE, "Got closest display mode: %ix%i@%i\n", got.w, got.h, got.refresh_rate);
#ifdef XASH_SDL_WINDOW_RECREATE
if( recreate )
{
SDL_DestroyWindow( host.hWnd );
host.hWnd = SDL_CreateWindow(wndname, 0, 0, width, height, wndFlags | SDL_WINDOW_OPENGL | SDL_WINDOW_SHOWN | SDL_WINDOW_BORDERLESS | SDL_WINDOW_INPUT_GRABBED );
SDL_GL_MakeCurrent( host.hWnd, glw_state.context );
recreate = false;
}
#endif
if( SDL_SetWindowDisplayMode( host.hWnd, &got) == -1 ) if( SDL_SetWindowDisplayMode( host.hWnd, &got) == -1 )
return false; return false;
if( SDL_SetWindowFullscreen( host.hWnd, SDL_WINDOW_FULLSCREEN) == -1 ) if( SDL_SetWindowFullscreen( host.hWnd, SDL_WINDOW_FULLSCREEN) == -1 )
return false; return false;
SDL_SetWindowBordered( host.hWnd, SDL_FALSE ); SDL_SetWindowBordered( host.hWnd, SDL_FALSE );
//SDL_SetWindowPosition( host.hWnd, 0, 0 ); //SDL_SetWindowPosition( host.hWnd, 0, 0 );
SDL_SetWindowGrab( host.hWnd, SDL_TRUE ); SDL_SetWindowGrab( host.hWnd, SDL_TRUE );
@ -428,14 +528,12 @@ void VID_RestoreScreenResolution( void )
if( !Cvar_VariableInteger("fullscreen") ) if( !Cvar_VariableInteger("fullscreen") )
{ {
SDL_SetWindowBordered( host.hWnd, SDL_TRUE ); SDL_SetWindowBordered( host.hWnd, SDL_TRUE );
//SDL_SetWindowPosition( host.hWnd, SDL_WINDOWPOS_CENTERED, SDL_WINDOWPOS_CENTERED );
SDL_SetWindowGrab( host.hWnd, SDL_FALSE ); SDL_SetWindowGrab( host.hWnd, SDL_FALSE );
} }
else else
{ {
SDL_MinimizeWindow( host.hWnd ); SDL_MinimizeWindow( host.hWnd );
SDL_SetWindowFullscreen( host.hWnd, 0 ); SDL_SetWindowFullscreen( host.hWnd, 0 );
recreate = true;
} }
} }
@ -462,8 +560,9 @@ VID_CreateWindow
qboolean VID_CreateWindow( int width, int height, qboolean fullscreen ) qboolean VID_CreateWindow( int width, int height, qboolean fullscreen )
{ {
static string wndname; static string wndname;
Uint32 wndFlags = SDL_WINDOW_OPENGL; Uint32 wndFlags = SDL_WINDOW_OPENGL | SDL_WINDOW_SHOWN | SDL_WINDOW_MOUSE_FOCUS;
rgbdata_t *icon = NULL; rgbdata_t *icon = NULL;
qboolean iconLoaded = false;
char iconpath[MAX_STRING]; char iconpath[MAX_STRING];
if( vid_highdpi->value ) wndFlags |= SDL_WINDOW_ALLOW_HIGHDPI; if( vid_highdpi->value ) wndFlags |= SDL_WINDOW_ALLOW_HIGHDPI;
@ -471,15 +570,16 @@ qboolean VID_CreateWindow( int width, int height, qboolean fullscreen )
if( !fullscreen ) if( !fullscreen )
{ {
#ifndef XASH_SDL_DISABLE_RESIZE
wndFlags |= SDL_WINDOW_RESIZABLE; wndFlags |= SDL_WINDOW_RESIZABLE;
#endif host.hWnd = SDL_CreateWindow( wndname,
host.hWnd = SDL_CreateWindow( wndname, window_xpos->value, Cvar_VariableInteger( "_window_xpos" ),
window_ypos->value, width, height, wndFlags | SDL_WINDOW_MOUSE_FOCUS ); Cvar_VariableInteger( "_window_ypos" ),
width, height, wndFlags );
} }
else else
{ {
host.hWnd = SDL_CreateWindow( wndname, 0, 0, width, height, wndFlags | SDL_WINDOW_FULLSCREEN | SDL_WINDOW_SHOWN | SDL_WINDOW_BORDERLESS | SDL_WINDOW_INPUT_GRABBED ); wndFlags |= SDL_WINDOW_FULLSCREEN | SDL_WINDOW_BORDERLESS | SDL_WINDOW_INPUT_GRABBED;
host.hWnd = SDL_CreateWindow( wndname, 0, 0, width, height, wndFlags );
} }
@ -522,16 +622,15 @@ qboolean VID_CreateWindow( int width, int height, qboolean fullscreen )
Q_snprintf( localPath, sizeof( localPath ), "%s/%s", GI->gamefolder, GI->iconpath ); Q_snprintf( localPath, sizeof( localPath ), "%s/%s", GI->gamefolder, GI->iconpath );
ico = (HICON)LoadImage( NULL, localPath, IMAGE_ICON, 0, 0, LR_LOADFROMFILE|LR_DEFAULTSIZE ); ico = (HICON)LoadImage( NULL, localPath, IMAGE_ICON, 0, 0, LR_LOADFROMFILE|LR_DEFAULTSIZE );
if( !ico ) if( ico )
{ {
MsgDev( D_INFO, "Extract %s from pak if you want to see it.\n", GI->iconpath ); iconLoaded = true;
ico = LoadIcon( host.hInst, MAKEINTRESOURCE( 101 ) );
}
WIN_SetWindowIcon( ico ); WIN_SetWindowIcon( ico );
} }
else }
#endif // _WIN32 && !XASH_64BIT #endif // _WIN32 && !XASH_64BIT
if( !iconLoaded )
{ {
Q_strcpy( iconpath, GI->iconpath ); Q_strcpy( iconpath, GI->iconpath );
COM_StripExtension( iconpath ); COM_StripExtension( iconpath );
@ -549,17 +648,20 @@ qboolean VID_CreateWindow( int width, int height, qboolean fullscreen )
{ {
SDL_SetWindowIcon( host.hWnd, surface ); SDL_SetWindowIcon( host.hWnd, surface );
SDL_FreeSurface( surface ); SDL_FreeSurface( surface );
iconLoaded = true;
} }
FS_FreeImage( icon ); FS_FreeImage( icon );
} }
}
#if defined(_WIN32) && !defined(XASH_64BIT) // ICO support only for Win32 #if defined(_WIN32) && !defined(XASH_64BIT) // ICO support only for Win32
else if( !iconLoaded )
{ {
WIN_SetWindowIcon( LoadIcon( host.hInst, MAKEINTRESOURCE( 101 ) ) ); WIN_SetWindowIcon( LoadIcon( host.hInst, MAKEINTRESOURCE( 101 ) ) );
iconLoaded = true;
} }
#endif #endif
}
SDL_ShowWindow( host.hWnd ); SDL_ShowWindow( host.hWnd );
if( !glw_state.initialized ) if( !glw_state.initialized )
@ -751,6 +853,13 @@ qboolean R_Init_OpenGL( void )
return false; return false;
} }
R_InitVideoModes();
// must be initialized before creating window
#ifdef _WIN32
WIN_SetDPIAwareness();
#endif
return VID_SetMode(); return VID_SetMode();
} }
@ -999,26 +1108,6 @@ void GL_InitExtensions( void )
glw_state.initialized = true; glw_state.initialized = true;
} }
int R_MaxVideoModes( void )
{
return num_vidmodes;
}
vidmode_t R_GetVideoMode( int num )
{
static vidmode_t error = { "NOMODE" };
if( num < 0 || num > num_vidmodes )
{
error.width = scr_width->value;
error.height = scr_height->value;
error.wideScreen = false;
return error;
}
return vidmode[num];
}
/* /*
================== ==================
R_ChangeDisplaySettingsFast R_ChangeDisplaySettingsFast
@ -1028,40 +1117,18 @@ Change window size fastly to custom values, without setting vid mode
*/ */
void R_ChangeDisplaySettingsFast( int width, int height ) void R_ChangeDisplaySettingsFast( int width, int height )
{ {
// Cvar_SetValue( "vid_mode", VID_NOMODE ); R_SaveVideoMode( width, height );
Cvar_SetValue( "width", width );
Cvar_SetValue( "height", height );
// as we don't recreate window here, update center positions by hand
host.window_center_x = glState.width / 2;
host.window_center_y = glState.height / 2;
if( glState.width != width || glState.height != height )
{
glState.width = width;
glState.height = height;
if( width * 3 != height * 4 && width * 4 != height * 5 )
glState.wideScreen = true;
else glState.wideScreen = false;
SCR_VidInit(); SCR_VidInit();
} }
}
rserr_t R_ChangeDisplaySettings( int width, int height, qboolean fullscreen ) rserr_t R_ChangeDisplaySettings( int width, int height, qboolean fullscreen )
{ {
SDL_DisplayMode displayMode; SDL_DisplayMode displayMode;
qboolean old_fullscreen = glState.fullScreen;
SDL_GetCurrentDisplayMode( 0, &displayMode ); SDL_GetCurrentDisplayMode( 0, &displayMode );
#ifdef XASH_NOMODESWITCH
width = displayMode.w;
height = displayMode.h;
fullscreen = false;
#endif
MsgDev( D_INFO, "R_ChangeDisplaySettings: Setting video mode to %dx%d %s\n", width, height, fullscreen ? "fullscreen" : "windowed" ); MsgDev( D_INFO, "R_ChangeDisplaySettings: Setting video mode to %dx%d %s\n", width, height, fullscreen ? "fullscreen" : "windowed" );
R_SaveVideoMode( width, height );
// check our desktop attributes // check our desktop attributes
glw_state.desktopBitsPixel = SDL_BITSPERPIXEL( displayMode.format ); glw_state.desktopBitsPixel = SDL_BITSPERPIXEL( displayMode.format );
@ -1070,24 +1137,17 @@ rserr_t R_ChangeDisplaySettings( int width, int height, qboolean fullscreen )
glState.fullScreen = fullscreen; glState.fullScreen = fullscreen;
// check for 4:3 or 5:4
if( width * 3 != height * 4 && width * 4 != height * 5 )
glState.wideScreen = true;
else glState.wideScreen = false;
if( !host.hWnd ) if( !host.hWnd )
{ {
if( !VID_CreateWindow( width, height, fullscreen ) ) if( !VID_CreateWindow( width, height, fullscreen ) )
return rserr_invalid_mode; return rserr_invalid_mode;
} }
#ifndef XASH_NOMODESWITCH
else if( fullscreen ) else if( fullscreen )
{ {
if( !VID_SetScreenResolution( width, height ) ) if( !VID_SetScreenResolution( width, height ) )
return rserr_invalid_fullscreen; return rserr_invalid_fullscreen;
} }
else if( old_fullscreen ) else
{ {
VID_RestoreScreenResolution(); VID_RestoreScreenResolution();
if( SDL_SetWindowFullscreen( host.hWnd, 0 ) ) if( SDL_SetWindowFullscreen( host.hWnd, 0 ) )
@ -1101,7 +1161,6 @@ rserr_t R_ChangeDisplaySettings( int width, int height, qboolean fullscreen )
SDL_GL_GetDrawableSize( host.hWnd, &width, &height ); SDL_GL_GetDrawableSize( host.hWnd, &width, &height );
R_ChangeDisplaySettingsFast( width, height ); R_ChangeDisplaySettingsFast( width, height );
} }
#endif
return rserr_ok; return rserr_ok;
} }
@ -1119,34 +1178,29 @@ qboolean VID_SetMode( void )
int iScreenWidth, iScreenHeight; int iScreenWidth, iScreenHeight;
rserr_t err; rserr_t err;
if( vid_mode->value == -1 ) // trying to get resolution automatically by default iScreenWidth = Cvar_VariableInteger( "width" );
iScreenHeight = Cvar_VariableInteger( "height" );
if( iScreenWidth < VID_MIN_WIDTH ||
iScreenHeight < VID_MIN_HEIGHT ) // trying to get resolution automatically by default
{ {
#if !defined( DEFAULT_MODE_WIDTH ) || !defined( DEFAULT_MODE_HEIGHT )
SDL_DisplayMode mode; SDL_DisplayMode mode;
#if !defined DEFAULT_MODE_WIDTH || !defined DEFAULT_MODE_HEIGHT
SDL_GetDesktopDisplayMode( 0, &mode ); SDL_GetDesktopDisplayMode( 0, &mode );
#else
mode.w = DEFAULT_MODE_WIDTH;
mode.h = DEFAULT_MODE_HEIGHT;
#endif
iScreenWidth = mode.w; iScreenWidth = mode.w;
iScreenHeight = mode.h; iScreenHeight = mode.h;
#else
iScreenWidth = DEFAULT_MODE_WIDTH;
iScreenHeight = DEFAULT_MODE_HEIGHT;
#endif
if( !FBitSet( vid_fullscreen->flags, FCVAR_CHANGED ) ) if( !FBitSet( vid_fullscreen->flags, FCVAR_CHANGED ) )
Cvar_SetValue( "fullscreen", DEFAULT_FULLSCREEN ); Cvar_SetValue( "fullscreen", DEFAULT_FULLSCREEN );
else else
ClearBits( vid_fullscreen->flags, FCVAR_CHANGED ); ClearBits( vid_fullscreen->flags, FCVAR_CHANGED );
} }
else if( FBitSet( vid_mode->flags, FCVAR_CHANGED ) && vid_mode->value >= 0 && vid_mode->value <= num_vidmodes )
{
iScreenWidth = vidmode[(int)vid_mode->value].width;
iScreenHeight = vidmode[(int)vid_mode->value].height;
}
else
{
iScreenHeight = scr_height->value;
iScreenWidth = scr_width->value;
}
SetBits( gl_vsync->flags, FCVAR_CHANGED ); SetBits( gl_vsync->flags, FCVAR_CHANGED );
fullscreen = Cvar_VariableInteger("fullscreen") != 0; fullscreen = Cvar_VariableInteger("fullscreen") != 0;
@ -1168,7 +1222,6 @@ qboolean VID_SetMode( void )
} }
else if( err == rserr_invalid_mode ) else if( err == rserr_invalid_mode )
{ {
Cvar_SetValue( "vid_mode", glConfig.prev_mode );
MsgDev( D_ERROR, "VID_SetMode: invalid mode\n" ); MsgDev( D_ERROR, "VID_SetMode: invalid mode\n" );
Sys_Warn( "invalid mode" ); Sys_Warn( "invalid mode" );
} }
@ -1195,6 +1248,8 @@ void R_Free_OpenGL( void )
VID_DestroyWindow (); VID_DestroyWindow ();
R_FreeVideoModes();
// now all extensions are disabled // now all extensions are disabled
memset( glConfig.extension, 0, sizeof( glConfig.extension )); memset( glConfig.extension, 0, sizeof( glConfig.extension ));
glw_state.initialized = false; glw_state.initialized = false;

View File

@ -322,11 +322,6 @@ bool CEngineSurface :: setFullscreenMode( int wide, int tall, int bpp )
{ {
// NOTE: Xash3D always working in 32-bit mode // NOTE: Xash3D always working in 32-bit mode
// Skip it now. VGUI cannot change video modes // Skip it now. VGUI cannot change video modes
/*if( R_DescribeVIDMode( wide, tall ))
{
Cvar_SetFloat( "fullscreen", 1.0f );
return true;
}*/
return false; return false;
} }