Commit 6c8cac10 authored by Jacek Caban's avatar Jacek Caban Committed by Alexandre Julliard

win32u: Move GetDpiForWindow from user32.

parent 72316326
...@@ -2099,35 +2099,7 @@ DPI_AWARENESS_CONTEXT WINAPI GetWindowDpiAwarenessContext( HWND hwnd ) ...@@ -2099,35 +2099,7 @@ DPI_AWARENESS_CONTEXT WINAPI GetWindowDpiAwarenessContext( HWND hwnd )
*/ */
UINT WINAPI GetDpiForWindow( HWND hwnd ) UINT WINAPI GetDpiForWindow( HWND hwnd )
{ {
WND *win; return NtUserCallHwnd( hwnd, NtUserGetDpiForWindow );
UINT ret = 0;
if (!(win = WIN_GetPtr( hwnd )))
{
SetLastError( ERROR_INVALID_WINDOW_HANDLE );
return 0;
}
if (win == WND_DESKTOP)
{
POINT pt = { 0, 0 };
return get_monitor_dpi( MonitorFromPoint( pt, MONITOR_DEFAULTTOPRIMARY ));
}
if (win != WND_OTHER_PROCESS)
{
ret = win->dpi;
if (!ret) ret = get_win_monitor_dpi( hwnd );
WIN_ReleasePtr( win );
}
else
{
SERVER_START_REQ( get_window_info )
{
req->handle = wine_server_user_handle( hwnd );
if (!wine_server_call_err( req )) ret = reply->dpi;
}
SERVER_END_REQ;
}
return ret;
} }
......
...@@ -1380,6 +1380,15 @@ UINT get_monitor_dpi( HMONITOR monitor ) ...@@ -1380,6 +1380,15 @@ UINT get_monitor_dpi( HMONITOR monitor )
} }
/********************************************************************** /**********************************************************************
* get_win_monitor_dpi
*/
UINT get_win_monitor_dpi( HWND hwnd )
{
/* FIXME: use the monitor DPI instead */
return system_dpi;
}
/**********************************************************************
* get_thread_dpi_awareness * get_thread_dpi_awareness
*/ */
static DPI_AWARENESS get_thread_dpi_awareness(void) static DPI_AWARENESS get_thread_dpi_awareness(void)
......
...@@ -284,6 +284,7 @@ extern LRESULT send_message( HWND hwnd, UINT msg, WPARAM wparam, LPARAM lparam ) ...@@ -284,6 +284,7 @@ extern LRESULT send_message( HWND hwnd, UINT msg, WPARAM wparam, LPARAM lparam )
/* sysparams.c */ /* sysparams.c */
extern RECT get_display_rect( const WCHAR *display ) DECLSPEC_HIDDEN; extern RECT get_display_rect( const WCHAR *display ) DECLSPEC_HIDDEN;
extern UINT get_monitor_dpi( HMONITOR monitor ) DECLSPEC_HIDDEN; extern UINT get_monitor_dpi( HMONITOR monitor ) DECLSPEC_HIDDEN;
extern UINT get_win_monitor_dpi( HWND hwnd ) DECLSPEC_HIDDEN;
extern UINT get_system_dpi(void) DECLSPEC_HIDDEN; extern UINT get_system_dpi(void) DECLSPEC_HIDDEN;
extern int get_system_metrics( int index ) DECLSPEC_HIDDEN; extern int get_system_metrics( int index ) DECLSPEC_HIDDEN;
extern UINT get_thread_dpi(void) DECLSPEC_HIDDEN; extern UINT get_thread_dpi(void) DECLSPEC_HIDDEN;
......
...@@ -708,6 +708,40 @@ static DPI_AWARENESS_CONTEXT get_window_dpi_awareness_context( HWND hwnd ) ...@@ -708,6 +708,40 @@ static DPI_AWARENESS_CONTEXT get_window_dpi_awareness_context( HWND hwnd )
return ret; return ret;
} }
/* see GetDpiForWindow */
static UINT get_dpi_for_window( HWND hwnd )
{
WND *win;
UINT ret = 0;
if (!(win = get_win_ptr( hwnd )))
{
SetLastError( ERROR_INVALID_WINDOW_HANDLE );
return 0;
}
if (win == WND_DESKTOP)
{
POINT pt = { 0, 0 };
return get_monitor_dpi( monitor_from_point( pt, MONITOR_DEFAULTTOPRIMARY, 0 ));
}
if (win != WND_OTHER_PROCESS)
{
ret = win->dpi;
if (!ret) ret = get_win_monitor_dpi( hwnd );
release_win_ptr( win );
}
else
{
SERVER_START_REQ( get_window_info )
{
req->handle = wine_server_user_handle( hwnd );
if (!wine_server_call_err( req )) ret = reply->dpi;
}
SERVER_END_REQ;
}
return ret;
}
static LONG_PTR get_win_data( const void *ptr, UINT size ) static LONG_PTR get_win_data( const void *ptr, UINT size )
{ {
if (size == sizeof(WORD)) if (size == sizeof(WORD))
...@@ -1115,6 +1149,8 @@ ULONG_PTR WINAPI NtUserCallHwnd( HWND hwnd, DWORD code ) ...@@ -1115,6 +1149,8 @@ ULONG_PTR WINAPI NtUserCallHwnd( HWND hwnd, DWORD code )
{ {
switch (code) switch (code)
{ {
case NtUserGetDpiForWindow:
return get_dpi_for_window( hwnd );
case NtUserGetParent: case NtUserGetParent:
return HandleToUlong( get_parent( hwnd )); return HandleToUlong( get_parent( hwnd ));
case NtUserGetWindowDpiAwarenessContext: case NtUserGetWindowDpiAwarenessContext:
......
...@@ -141,6 +141,7 @@ enum ...@@ -141,6 +141,7 @@ enum
/* NtUserCallHwnd codes, not compatible with Windows */ /* NtUserCallHwnd codes, not compatible with Windows */
enum enum
{ {
NtUserGetDpiForWindow,
NtUserGetParent, NtUserGetParent,
NtUserGetWindowDpiAwarenessContext, NtUserGetWindowDpiAwarenessContext,
NtUserGetWindowTextLength, NtUserGetWindowTextLength,
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment