win32: Use the current flags to determine if NCCALCSIZE is required

SDL_GetWindowFlags() also ORs in pending flags, whereas the current state is needed here, particularly when creating/showing a window.

(cherry picked from commit cd0c660dea)
This commit is contained in:
Frank Praznik
2025-08-05 17:24:10 -04:00
parent 1a2841deb1
commit 5e77fb314c
2 changed files with 10 additions and 10 deletions

View File

@@ -2201,7 +2201,7 @@ LRESULT CALLBACK WIN_WindowProc(HWND hwnd, UINT msg, WPARAM wParam, LPARAM lPara
case WM_NCCALCSIZE:
{
SDL_WindowFlags window_flags = SDL_GetWindowFlags(data->window);
SDL_WindowFlags window_flags = data->window->flags;
if (wParam == TRUE && (window_flags & SDL_WINDOW_BORDERLESS) && !(window_flags & SDL_WINDOW_FULLSCREEN)) {
// When borderless, need to tell windows that the size of the non-client area is 0
NCCALCSIZE_PARAMS *params = (NCCALCSIZE_PARAMS *)lParam;

View File

@@ -1043,16 +1043,16 @@ void WIN_ShowWindow(SDL_VideoDevice *_this, SDL_Window *window)
WIN_SetWindowPosition(_this, window);
}
/* If the window will immediately become fullscreen, use the borderless style to hide the initial borders.
*
* Note: The combination of flags used in STYLE_BORDERLESS_WINDOWED will still briefly show the borders if
* the initial window size exactly matches the desktop, so STYLE_BORDERLESS must be used instead.
*/
// If the window isn't borderless and will be fullscreen, use the borderless style to hide the initial borders.
if (window->pending_flags & SDL_WINDOW_FULLSCREEN) {
style = GetWindowLong(hwnd, GWL_STYLE);
style &= ~STYLE_MASK;
style |= STYLE_BORDERLESS;
SetWindowLong(hwnd, GWL_STYLE, style);
if (!(window->flags & SDL_WINDOW_BORDERLESS)) {
window->flags |= SDL_WINDOW_BORDERLESS;
style = GetWindowLong(hwnd, GWL_STYLE);
style &= ~STYLE_MASK;
style |= GetWindowStyle(window);
SetWindowLong(hwnd, GWL_STYLE, style);
window->flags &= ~SDL_WINDOW_BORDERLESS;
}
}
style = GetWindowLong(hwnd, GWL_EXSTYLE);
if (style & WS_EX_NOACTIVATE) {