diff options
author | rubidium <rubidium@openttd.org> | 2008-08-13 19:09:27 +0000 |
---|---|---|
committer | rubidium <rubidium@openttd.org> | 2008-08-13 19:09:27 +0000 |
commit | 20ee6f11587a24de3aac36e5b4e54ee13f76e352 (patch) | |
tree | b0e6c920c8058ad64855dd03bd1bd55aebd6844a /src/video | |
parent | d986380169d2deb1c581ed0d08685f12c26dcf33 (diff) | |
download | openttd-20ee6f11587a24de3aac36e5b4e54ee13f76e352.tar.xz |
(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.
Diffstat (limited to 'src/video')
-rw-r--r-- | src/video/win32_v.cpp | 10 |
1 files changed, 8 insertions, 2 deletions
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 <windows.h> #include <tchar.h> +/** Only MSVC has this header, MinGW supplies the required constants itself */ +#ifdef _MSC_VER +# define COMPILE_MULTIMON_STUBS +# include <multimon.h> +#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 |