Implement DPI scaling for Windows (#9586)

This commit is contained in:
sfan5 2020-04-11 20:03:59 +02:00 committed by GitHub
parent 5cc06e4748
commit 40df3931d8
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
5 changed files with 69 additions and 25 deletions

@ -8,8 +8,8 @@
</security> </security>
</trustInfo> </trustInfo>
<application xmlns="urn:schemas-microsoft-com:asm.v3"> <application xmlns="urn:schemas-microsoft-com:asm.v3">
<windowsSettings> <windowsSettings xmlns="http://schemas.microsoft.com/SMI/2005/WindowsSettings">
<dpiAware xmlns="http://schemas.microsoft.com/SMI/2005/WindowsSettings">true</dpiAware> <dpiAware>true</dpiAware>
</windowsSettings> </windowsSettings>
</application> </application>
</assembly> </assembly>

@ -1,6 +1,8 @@
#include <windows.h> #include <windows.h>
#include <winuser.h>
#include <commctrl.h> #include <commctrl.h>
#include <richedit.h> #include <richedit.h>
#ifndef USE_CMAKE_CONFIG_H #ifndef USE_CMAKE_CONFIG_H
#define USE_CMAKE_CONFIG_H #define USE_CMAKE_CONFIG_H
#endif #endif
@ -13,6 +15,10 @@
#define BUILDMODE "RUN_IN_PLACE=0" #define BUILDMODE "RUN_IN_PLACE=0"
#endif #endif
#ifdef __MINGW32__
CREATEPROCESS_MANIFEST_RESOURCE_ID RT_MANIFEST "minetest.exe.manifest"
#endif
LANGUAGE 0, SUBLANG_NEUTRAL LANGUAGE 0, SUBLANG_NEUTRAL
130 ICON "minetest-icon.ico" 130 ICON "minetest-icon.ico"

@ -451,7 +451,7 @@ if(WIN32)
-i${WINRESOURCE_FILE} -i${WINRESOURCE_FILE}
-o ${CMAKE_CURRENT_BINARY_DIR}/winresource_rc.o -o ${CMAKE_CURRENT_BINARY_DIR}/winresource_rc.o
WORKING_DIRECTORY ${CMAKE_CURRENT_SOURCE_DIR} WORKING_DIRECTORY ${CMAKE_CURRENT_SOURCE_DIR}
DEPENDS ${WINRESOURCE_FILE}) DEPENDS ${WINRESOURCE_FILE} ${MINETEST_EXE_MANIFEST_FILE})
SET(extra_windows_SRCS ${CMAKE_CURRENT_BINARY_DIR}/winresource_rc.o) SET(extra_windows_SRCS ${CMAKE_CURRENT_BINARY_DIR}/winresource_rc.o)
else(MINGW) # Probably MSVC else(MINGW) # Probably MSVC
set(extra_windows_SRCS ${WINRESOURCE_FILE} ${MINETEST_EXE_MANIFEST_FILE}) set(extra_windows_SRCS ${WINRESOURCE_FILE} ${MINETEST_EXE_MANIFEST_FILE})

@ -45,7 +45,11 @@ with this program; if not, write to the Free Software Foundation, Inc.,
#include <X11/Xlib.h> #include <X11/Xlib.h>
#include <X11/Xutil.h> #include <X11/Xutil.h>
#include <X11/Xatom.h> #include <X11/Xatom.h>
#endif
#ifdef _WIN32
#include <windows.h>
#include <winuser.h>
#endif #endif
#if ENABLE_GLES #if ENABLE_GLES
@ -318,6 +322,28 @@ void RenderingEngine::setupTopLevelXorgWindow(const std::string &name)
#endif #endif
} }
#ifdef _WIN32
static bool getWindowHandle(irr::video::IVideoDriver *driver, HWND &hWnd)
{
const video::SExposedVideoData exposedData = driver->getExposedVideoData();
switch (driver->getDriverType()) {
case video::EDT_DIRECT3D8:
hWnd = reinterpret_cast<HWND>(exposedData.D3D8.HWnd);
break;
case video::EDT_DIRECT3D9:
hWnd = reinterpret_cast<HWND>(exposedData.D3D9.HWnd);
break;
case video::EDT_OPENGL:
hWnd = reinterpret_cast<HWND>(exposedData.OpenGLWin32.HWnd);
break;
default:
return false;
}
return true;
}
#endif
bool RenderingEngine::setWindowIcon() bool RenderingEngine::setWindowIcon()
{ {
@ -335,22 +361,9 @@ bool RenderingEngine::setWindowIcon()
"-xorg-icon-128.png"); "-xorg-icon-128.png");
#endif #endif
#elif defined(_WIN32) #elif defined(_WIN32)
const video::SExposedVideoData exposedData = driver->getExposedVideoData();
HWND hWnd; // Window handle HWND hWnd; // Window handle
if (!getWindowHandle(driver, hWnd))
switch (driver->getDriverType()) {
case video::EDT_DIRECT3D8:
hWnd = reinterpret_cast<HWND>(exposedData.D3D8.HWnd);
break;
case video::EDT_DIRECT3D9:
hWnd = reinterpret_cast<HWND>(exposedData.D3D9.HWnd);
break;
case video::EDT_OPENGL:
hWnd = reinterpret_cast<HWND>(exposedData.OpenGLWin32.HWnd);
break;
default:
return false; return false;
}
// Load the ICON from resource file // Load the ICON from resource file
const HICON hicon = LoadIcon(GetModuleHandle(NULL), const HICON hicon = LoadIcon(GetModuleHandle(NULL),
@ -632,7 +645,7 @@ const char *RenderingEngine::getVideoDriverFriendlyName(irr::video::E_DRIVER_TYP
} }
#ifndef __ANDROID__ #ifndef __ANDROID__
#ifdef XORG_USED #if defined(XORG_USED)
static float calcDisplayDensity() static float calcDisplayDensity()
{ {
@ -667,12 +680,42 @@ float RenderingEngine::getDisplayDensity()
return cached_display_density; return cached_display_density;
} }
#else // XORG_USED #elif defined(_WIN32)
static float calcDisplayDensity(irr::video::IVideoDriver *driver)
{
HWND hWnd;
if (getWindowHandle(driver, hWnd)) {
HDC hdc = GetDC(hWnd);
float dpi = GetDeviceCaps(hdc, LOGPIXELSX);
ReleaseDC(hWnd, hdc);
return dpi / 96.0f;
}
/* return manually specified dpi */
return g_settings->getFloat("screen_dpi") / 96.0f;
}
float RenderingEngine::getDisplayDensity()
{
static bool cached = false;
static float display_density;
if (!cached) {
display_density = calcDisplayDensity(get_video_driver());
cached = true;
}
return display_density;
}
#else
float RenderingEngine::getDisplayDensity() float RenderingEngine::getDisplayDensity()
{ {
return g_settings->getFloat("screen_dpi") / 96.0; return g_settings->getFloat("screen_dpi") / 96.0;
} }
#endif // XORG_USED
#endif
v2u32 RenderingEngine::getDisplaySize() v2u32 RenderingEngine::getDisplaySize()
{ {

@ -110,10 +110,5 @@ with this program; if not, write to the Free Software Foundation, Inc.,
GUI related things GUI related things
*/ */
// TODO: implement dpi-based scaling for windows and remove this hack
#if defined(_WIN32)
#define TTF_DEFAULT_FONT_SIZE (18)
#else
#define TTF_DEFAULT_FONT_SIZE (16) #define TTF_DEFAULT_FONT_SIZE (16)
#endif
#define DEFAULT_FONT_SIZE (10) #define DEFAULT_FONT_SIZE (10)