diff --git a/editor/settings/editor_settings.cpp b/editor/settings/editor_settings.cpp index 22db86c60eb9..010cb104bec6 100644 --- a/editor/settings/editor_settings.cpp +++ b/editor/settings/editor_settings.cpp @@ -1829,6 +1829,9 @@ float EditorSettings::get_auto_display_scale() { return 1.0; } +#if defined(WINDOWS_ENABLED) + return DisplayServer::get_singleton()->screen_get_dpi(screen) / 96.0; +#else // Use the smallest dimension to use a correct display scale on portrait displays. const int smallest_dimension = MIN(DisplayServer::get_singleton()->screen_get_size(screen).x, DisplayServer::get_singleton()->screen_get_size(screen).y); if (DisplayServer::get_singleton()->screen_get_dpi(screen) >= 192 && smallest_dimension >= 1400) { @@ -1845,6 +1848,8 @@ float EditorSettings::get_auto_display_scale() { } return 1.0; #endif + +#endif } // Shortcuts diff --git a/platform/windows/display_server_windows.cpp b/platform/windows/display_server_windows.cpp index 475fd942b769..a324891e67ad 100644 --- a/platform/windows/display_server_windows.cpp +++ b/platform/windows/display_server_windows.cpp @@ -1330,17 +1330,17 @@ Rect2i DisplayServerWindows::screen_get_usable_rect(int p_screen) const { } typedef struct { - int count; + int current_index; int screen; int dpi; } EnumDpiData; -static int QueryDpiForMonitor(HMONITOR hmon, MONITOR_DPI_TYPE dpiType = MDT_DEFAULT) { +static int QueryDpiForMonitor(HMONITOR hmon) { int dpiX = 96, dpiY = 96; UINT x = 0, y = 0; if (hmon) { - HRESULT hr = GetDpiForMonitor(hmon, dpiType, &x, &y); + HRESULT hr = GetDpiForMonitor(hmon, MDT_DEFAULT, &x, &y); if (SUCCEEDED(hr) && (x > 0) && (y > 0)) { dpiX = (int)x; dpiY = (int)y; @@ -1366,11 +1366,13 @@ static int QueryDpiForMonitor(HMONITOR hmon, MONITOR_DPI_TYPE dpiType = MDT_DEFA static BOOL CALLBACK _MonitorEnumProcDpi(HMONITOR hMonitor, HDC hdcMonitor, LPRECT lprcMonitor, LPARAM dwData) { EnumDpiData *data = (EnumDpiData *)dwData; - if (data->count == data->screen) { + + data->current_index++; + + if (data->current_index == data->screen) { data->dpi = QueryDpiForMonitor(hMonitor); + return FALSE; } - - data->count++; return TRUE; } @@ -1378,11 +1380,11 @@ int DisplayServerWindows::screen_get_dpi(int p_screen) const { _THREAD_SAFE_METHOD_ p_screen = _get_screen_index(p_screen); - int screen_count = get_screen_count(); - ERR_FAIL_INDEX_V(p_screen, screen_count, 72); - EnumDpiData data = { 0, p_screen, 72 }; + EnumDpiData data = { -1, p_screen, 96 }; EnumDisplayMonitors(nullptr, nullptr, _MonitorEnumProcDpi, (LPARAM)&data); + + ERR_FAIL_COND_V_MSG(data.current_index < p_screen, 96, vformat("Screen index %d out of range [0, %d].", p_screen, data.current_index)); return data.dpi; }