From 20ee6f11587a24de3aac36e5b4e54ee13f76e352 Mon Sep 17 00:00:00 2001 From: rubidium Date: Wed, 13 Aug 2008 19:09:27 +0000 Subject: (svn r14071) -Fix [FS#2057]: the screen wouldn't be centered on Windows multimonitor systems if the first monitor is right of the second one. --- src/video/win32_v.cpp | 10 ++++++++-- 1 file changed, 8 insertions(+), 2 deletions(-) (limited to 'src/video') diff --git a/src/video/win32_v.cpp b/src/video/win32_v.cpp index 9f5c32045..ba60df200 100644 --- a/src/video/win32_v.cpp +++ b/src/video/win32_v.cpp @@ -18,6 +18,12 @@ #include #include +/** Only MSVC has this header, MinGW supplies the required constants itself */ +#ifdef _MSC_VER +# define COMPILE_MULTIMON_STUBS +# include +#endif /* _MSC_VER */ + static struct { HWND main_wnd; HBITMAP dib_sect; @@ -280,8 +286,8 @@ static bool MakeWindow(bool full_screen) #endif w = r.right - r.left; h = r.bottom - r.top; - x = (GetSystemMetrics(SM_CXSCREEN) - w) / 2; - y = (GetSystemMetrics(SM_CYSCREEN) - h) / 2; + x = ((GetSystemMetrics(SM_CXVIRTUALSCREEN) - w) / 2) - GetSystemMetrics(SM_XVIRTUALSCREEN); + y = ((GetSystemMetrics(SM_CYVIRTUALSCREEN) - h) / 2) - GetSystemMetrics(SM_YVIRTUALSCREEN); if (_wnd.main_wnd) { ShowWindow(_wnd.main_wnd, SW_SHOWNORMAL); // remove maximize-flag -- cgit v1.2.3-70-g09d2