From: DeaDDooMER Date: Mon, 24 Sep 2018 12:02:50 +0000 (+0300) Subject: Default window size and position setted according with display resolution X-Git-Url: http://deadsoftware.ru/gitweb?a=commitdiff_plain;h=44bf4b6ea7ee66b36c3cb86c33c180e69f7dc1ba;p=d2df-sdl.git Default window size and position setted according with display resolution --- diff --git a/src/game/g_options.pas b/src/game/g_options.pas index 493e07c..60b067e 100644 --- a/src/game/g_options.pas +++ b/src/game/g_options.pas @@ -140,37 +140,38 @@ uses g_items, wadreader, e_graphics, g_touch, SDL2; procedure g_Options_SetDefaultVideo; -{$IF DEFINED(ANDROID)} var - display: TSDL_DisplayMode; -{$ENDIF} + target, closest, display: TSDL_DisplayMode; begin + (* Display 0 = Primary display *) + SDL_GetDesktopDisplayMode(0, @display); {$IF DEFINED(ANDROID)} - (* On android set max screen size *) - SDL_GetCurrentDisplayMode(0, @display); gScreenWidth := display.w; gScreenHeight := display.h; - gWinRealPosX := 0; - gWinRealPosY := 0; - gWinMaximized := False; - gFullScreen := False; (* if True then rotation not allowed *) + //gBPP := SDL_BITSPERPIXEL(dispaly.format); gBPP := 32; - gVSync := True; - gTextureFilter := True; - glLegacyNPOT := False; + gFullScreen := True; (* rotation not allowed? *) {$ELSE} - (* On other systems use default 800x600 *) - gScreenWidth := 800; - gScreenHeight := 600; - gWinRealPosX := 0; - gWinRealPosY := 0; - gWinMaximized := False; - gFullScreen := False; + (* Window must be smaller than display *) + target.w := display.w * 75 div 100; + target.h := display.h * 75 div 100; + target.format := 0; (* didn't care *) + target.refresh_rate := 0; (* didn't care *) + target.driverdata := nil; (* init *) + SDL_GetClosestDisplayMode(0, @target, @closest); + gScreenWidth := closest.w; + gScreenHeight := closest.h; + //gBPP := SDL_BITSPERPIXEL(closest.format); (* Resolution list didn't work for some reason *) gBPP := 32; - gVSync := True; - gTextureFilter := True; - glLegacyNPOT := False; + gFullScreen := False; {$ENDIF} + (* Must be positioned on primary display *) + gWinRealPosX := SDL_WINDOWPOS_CENTERED; + gWinRealPosY := SDL_WINDOWPOS_CENTERED; + gWinMaximized := False; + gVSync := True; + gTextureFilter := True; + glLegacyNPOT := False; e_LogWriteLn('g_Options_SetDefaultVideo: w = ' + IntToStr(gScreenWidth) + ' h = ' + IntToStr(gScreenHeight)); end;