user32: Use get_primary_monitor_rect() helper.
Signed-off-by: Zhiyi Zhang <zzhang@codeweavers.com> Signed-off-by: Alexandre Julliard <julliard@winehq.org>
This commit is contained in:
parent
59e5a8d055
commit
9b2f59cb94
|
@ -195,17 +195,15 @@ static void update_mouse_coords( INPUT *input )
|
||||||
if (input->u.mi.dwFlags & MOUSEEVENTF_ABSOLUTE)
|
if (input->u.mi.dwFlags & MOUSEEVENTF_ABSOLUTE)
|
||||||
{
|
{
|
||||||
DPI_AWARENESS_CONTEXT context = SetThreadDpiAwarenessContext( DPI_AWARENESS_CONTEXT_PER_MONITOR_AWARE );
|
DPI_AWARENESS_CONTEXT context = SetThreadDpiAwarenessContext( DPI_AWARENESS_CONTEXT_PER_MONITOR_AWARE );
|
||||||
|
RECT rc;
|
||||||
|
|
||||||
if (input->u.mi.dwFlags & MOUSEEVENTF_VIRTUALDESK)
|
if (input->u.mi.dwFlags & MOUSEEVENTF_VIRTUALDESK)
|
||||||
{
|
rc = get_virtual_screen_rect();
|
||||||
RECT rc = get_virtual_screen_rect();
|
else
|
||||||
|
rc = get_primary_monitor_rect();
|
||||||
|
|
||||||
input->u.mi.dx = rc.left + ((input->u.mi.dx * (rc.right - rc.left)) >> 16);
|
input->u.mi.dx = rc.left + ((input->u.mi.dx * (rc.right - rc.left)) >> 16);
|
||||||
input->u.mi.dy = rc.top + ((input->u.mi.dy * (rc.bottom - rc.top)) >> 16);
|
input->u.mi.dy = rc.top + ((input->u.mi.dy * (rc.bottom - rc.top)) >> 16);
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
input->u.mi.dx = (input->u.mi.dx * GetSystemMetrics( SM_CXSCREEN )) >> 16;
|
|
||||||
input->u.mi.dy = (input->u.mi.dy * GetSystemMetrics( SM_CYSCREEN )) >> 16;
|
|
||||||
}
|
|
||||||
SetThreadDpiAwarenessContext( context );
|
SetThreadDpiAwarenessContext( context );
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
|
|
|
@ -366,7 +366,7 @@ static BOOL CALLBACK get_primary_monitor_proc( HMONITOR monitor, HDC hdc, LPRECT
|
||||||
return TRUE;
|
return TRUE;
|
||||||
}
|
}
|
||||||
|
|
||||||
static RECT get_primary_monitor_rect(void)
|
RECT get_primary_monitor_rect(void)
|
||||||
{
|
{
|
||||||
RECT rect = {0};
|
RECT rect = {0};
|
||||||
|
|
||||||
|
@ -1818,9 +1818,7 @@ BOOL WINAPI SystemParametersInfoW( UINT uiAction, UINT uiParam,
|
||||||
spi_idx = SPI_SETWORKAREA_IDX;
|
spi_idx = SPI_SETWORKAREA_IDX;
|
||||||
if (!spi_loaded[spi_idx])
|
if (!spi_loaded[spi_idx])
|
||||||
{
|
{
|
||||||
SetRect( &work_area, 0, 0,
|
work_area = get_primary_monitor_rect();
|
||||||
GetSystemMetrics( SM_CXSCREEN ),
|
|
||||||
GetSystemMetrics( SM_CYSCREEN ) );
|
|
||||||
EnumDisplayMonitors( 0, NULL, enum_monitors, (LPARAM)&work_area );
|
EnumDisplayMonitors( 0, NULL, enum_monitors, (LPARAM)&work_area );
|
||||||
spi_loaded[spi_idx] = TRUE;
|
spi_loaded[spi_idx] = TRUE;
|
||||||
}
|
}
|
||||||
|
|
|
@ -261,6 +261,7 @@ extern void update_window_state( HWND hwnd ) DECLSPEC_HIDDEN;
|
||||||
extern void wait_graphics_driver_ready(void) DECLSPEC_HIDDEN;
|
extern void wait_graphics_driver_ready(void) DECLSPEC_HIDDEN;
|
||||||
extern void *get_hook_proc( void *proc, const WCHAR *module, HMODULE *free_module ) DECLSPEC_HIDDEN;
|
extern void *get_hook_proc( void *proc, const WCHAR *module, HMODULE *free_module ) DECLSPEC_HIDDEN;
|
||||||
extern RECT get_virtual_screen_rect(void) DECLSPEC_HIDDEN;
|
extern RECT get_virtual_screen_rect(void) DECLSPEC_HIDDEN;
|
||||||
|
extern RECT get_primary_monitor_rect(void) DECLSPEC_HIDDEN;
|
||||||
extern LRESULT call_current_hook( HHOOK hhook, INT code, WPARAM wparam, LPARAM lparam ) DECLSPEC_HIDDEN;
|
extern LRESULT call_current_hook( HHOOK hhook, INT code, WPARAM wparam, LPARAM lparam ) DECLSPEC_HIDDEN;
|
||||||
extern DWORD get_input_codepage( void ) DECLSPEC_HIDDEN;
|
extern DWORD get_input_codepage( void ) DECLSPEC_HIDDEN;
|
||||||
extern BOOL map_wparam_AtoW( UINT message, WPARAM *wparam, enum wm_char_mapping mapping ) DECLSPEC_HIDDEN;
|
extern BOOL map_wparam_AtoW( UINT message, WPARAM *wparam, enum wm_char_mapping mapping ) DECLSPEC_HIDDEN;
|
||||||
|
|
|
@ -855,8 +855,7 @@ BOOL WIN_GetRectangles( HWND hwnd, enum coords_relative relative, RECT *rectWind
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
rect.right = GetSystemMetrics(SM_CXSCREEN);
|
rect = get_primary_monitor_rect();
|
||||||
rect.bottom = GetSystemMetrics(SM_CYSCREEN);
|
|
||||||
}
|
}
|
||||||
if (rectWindow) *rectWindow = rect;
|
if (rectWindow) *rectWindow = rect;
|
||||||
if (rectClient) *rectClient = rect;
|
if (rectClient) *rectClient = rect;
|
||||||
|
|
|
@ -740,7 +740,7 @@ MINMAXINFO WINPOS_GetMinMaxInfo( HWND hwnd )
|
||||||
|
|
||||||
if ((monitor = MonitorFromWindow( hwnd, MONITOR_DEFAULTTOPRIMARY )))
|
if ((monitor = MonitorFromWindow( hwnd, MONITOR_DEFAULTTOPRIMARY )))
|
||||||
{
|
{
|
||||||
RECT rc_work;
|
RECT rc_work, rc_primary;
|
||||||
MONITORINFO mon_info;
|
MONITORINFO mon_info;
|
||||||
|
|
||||||
mon_info.cbSize = sizeof(mon_info);
|
mon_info.cbSize = sizeof(mon_info);
|
||||||
|
@ -754,8 +754,9 @@ MINMAXINFO WINPOS_GetMinMaxInfo( HWND hwnd )
|
||||||
rc_work = mon_info.rcWork;
|
rc_work = mon_info.rcWork;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (MinMax.ptMaxSize.x == GetSystemMetrics(SM_CXSCREEN) + 2 * xinc &&
|
rc_primary = get_primary_monitor_rect();
|
||||||
MinMax.ptMaxSize.y == GetSystemMetrics(SM_CYSCREEN) + 2 * yinc)
|
if (MinMax.ptMaxSize.x == (rc_primary.right - rc_primary.left) + 2 * xinc &&
|
||||||
|
MinMax.ptMaxSize.y == (rc_primary.bottom - rc_primary.top) + 2 * yinc)
|
||||||
{
|
{
|
||||||
MinMax.ptMaxSize.x = (rc_work.right - rc_work.left) + 2 * xinc;
|
MinMax.ptMaxSize.x = (rc_work.right - rc_work.left) + 2 * xinc;
|
||||||
MinMax.ptMaxSize.y = (rc_work.bottom - rc_work.top) + 2 * yinc;
|
MinMax.ptMaxSize.y = (rc_work.bottom - rc_work.top) + 2 * yinc;
|
||||||
|
|
Loading…
Reference in New Issue