Commit 48441212 authored by Jacek Caban's avatar Jacek Caban Committed by Alexandre Julliard

win32u: Move scroll bar proc implementation from user32.

parent 9d3058aa
...@@ -311,42 +311,6 @@ void WINAPI USER_ScrollBarDraw( HWND hwnd, HDC hdc, INT nBar, enum SCROLL_HITTES ...@@ -311,42 +311,6 @@ void WINAPI USER_ScrollBarDraw( HWND hwnd, HDC hdc, INT nBar, enum SCROLL_HITTES
} }
} }
/***********************************************************************
* SCROLL_HandleKbdEvent
*
* Handle a keyboard event (only for SB_CTL scrollbars with focus).
*
* PARAMS
* hwnd [I] Handle of window with scrollbar(s)
* wParam [I] Variable input including enable state
* lParam [I] Variable input including input point
*/
static void SCROLL_HandleKbdEvent(HWND hwnd, WPARAM wParam, LPARAM lParam)
{
TRACE("hwnd=%p wParam=%Id lParam=%Id\n", hwnd, wParam, lParam);
/* hide caret on first KEYDOWN to prevent flicker */
if ((lParam & PFD_DOUBLEBUFFER_DONTCARE) == 0)
NtUserHideCaret( hwnd );
switch(wParam)
{
case VK_PRIOR: wParam = SB_PAGEUP; break;
case VK_NEXT: wParam = SB_PAGEDOWN; break;
case VK_HOME: wParam = SB_TOP; break;
case VK_END: wParam = SB_BOTTOM; break;
case VK_UP: wParam = SB_LINEUP; break;
case VK_DOWN: wParam = SB_LINEDOWN; break;
case VK_LEFT: wParam = SB_LINEUP; break;
case VK_RIGHT: wParam = SB_LINEDOWN; break;
default: return;
}
SendMessageW(GetParent(hwnd),
((GetWindowLongW( hwnd, GWL_STYLE ) & SBS_VERT) ?
WM_VSCROLL : WM_HSCROLL), wParam, (LPARAM)hwnd);
}
/************************************************************************* /*************************************************************************
* SCROLL_GetScrollPos * SCROLL_GetScrollPos
* *
...@@ -391,18 +355,10 @@ static BOOL SCROLL_GetScrollRange(HWND hwnd, INT nBar, LPINT lpMin, LPINT lpMax) ...@@ -391,18 +355,10 @@ static BOOL SCROLL_GetScrollRange(HWND hwnd, INT nBar, LPINT lpMin, LPINT lpMax)
LRESULT WINAPI USER_ScrollBarProc( HWND hwnd, UINT message, WPARAM wParam, LPARAM lParam, BOOL unicode ) LRESULT WINAPI USER_ScrollBarProc( HWND hwnd, UINT message, WPARAM wParam, LPARAM lParam, BOOL unicode )
{ {
if (!IsWindow( hwnd )) return 0;
switch(message) switch(message)
{ {
case WM_KEYDOWN: case WM_KEYDOWN:
SCROLL_HandleKbdEvent(hwnd, wParam, lParam);
break;
case WM_KEYUP: case WM_KEYUP:
NtUserShowCaret( hwnd );
break;
case WM_ENABLE: case WM_ENABLE:
case WM_SETFOCUS: case WM_SETFOCUS:
case WM_KILLFOCUS: case WM_KILLFOCUS:
...@@ -415,28 +371,11 @@ LRESULT WINAPI USER_ScrollBarProc( HWND hwnd, UINT message, WPARAM wParam, LPARA ...@@ -415,28 +371,11 @@ LRESULT WINAPI USER_ScrollBarProc( HWND hwnd, UINT message, WPARAM wParam, LPARA
case SBM_GETSCROLLINFO: case SBM_GETSCROLLINFO:
case SBM_GETSCROLLBARINFO: case SBM_GETSCROLLBARINFO:
case SBM_SETSCROLLINFO: case SBM_SETSCROLLINFO:
return NtUserMessageCall( hwnd, message, wParam, lParam, 0, NtUserScrollBarWndProc, !unicode );
case WM_SETCURSOR: case WM_SETCURSOR:
if (GetWindowLongW( hwnd, GWL_STYLE ) & SBS_SIZEGRIP)
{
ULONG_PTR cursor = (GetWindowLongW( hwnd, GWL_EXSTYLE ) & WS_EX_LAYOUTRTL) ? IDC_SIZENESW : IDC_SIZENWSE;
return (LRESULT)NtUserSetCursor( LoadCursorA( 0, (LPSTR)cursor ));
}
return DefWindowProcW( hwnd, message, wParam, lParam );
case SBM_SETPOS: case SBM_SETPOS:
return SetScrollPos( hwnd, SB_CTL, wParam, (BOOL)lParam );
case SBM_GETPOS: case SBM_GETPOS:
return SCROLL_GetScrollPos(hwnd, SB_CTL);
case SBM_GETRANGE: case SBM_GETRANGE:
return SCROLL_GetScrollRange(hwnd, SB_CTL, (LPINT)wParam, (LPINT)lParam);
case SBM_ENABLE_ARROWS: case SBM_ENABLE_ARROWS:
return NtUserEnableScrollBar( hwnd, SB_CTL, wParam );
case 0x00e5: case 0x00e5:
case 0x00e7: case 0x00e7:
case 0x00e8: case 0x00e8:
...@@ -444,9 +383,7 @@ LRESULT WINAPI USER_ScrollBarProc( HWND hwnd, UINT message, WPARAM wParam, LPARA ...@@ -444,9 +383,7 @@ LRESULT WINAPI USER_ScrollBarProc( HWND hwnd, UINT message, WPARAM wParam, LPARA
case 0x00ed: case 0x00ed:
case 0x00ee: case 0x00ee:
case 0x00ef: case 0x00ef:
ERR("unknown Win32 msg %04x wp=%08Ix lp=%08Ix\n", return NtUserMessageCall( hwnd, message, wParam, lParam, 0, NtUserScrollBarWndProc, !unicode );
message, wParam, lParam );
break;
default: default:
if (message >= WM_USER) if (message >= WM_USER)
......
...@@ -1130,6 +1130,32 @@ static void create_scroll_bar( HWND hwnd, CREATESTRUCTW *create ) ...@@ -1130,6 +1130,32 @@ static void create_scroll_bar( HWND hwnd, CREATESTRUCTW *create )
} }
} }
static void handle_kbd_event( HWND hwnd, WPARAM wparam, LPARAM lparam )
{
TRACE( "hwnd=%p wparam=%ld lparam=%ld\n", hwnd, wparam, lparam );
/* hide caret on first KEYDOWN to prevent flicker */
if ((lparam & PFD_DOUBLEBUFFER_DONTCARE) == 0)
NtUserHideCaret( hwnd );
switch (wparam)
{
case VK_PRIOR: wparam = SB_PAGEUP; break;
case VK_NEXT: wparam = SB_PAGEDOWN; break;
case VK_HOME: wparam = SB_TOP; break;
case VK_END: wparam = SB_BOTTOM; break;
case VK_UP: wparam = SB_LINEUP; break;
case VK_DOWN: wparam = SB_LINEDOWN; break;
case VK_LEFT: wparam = SB_LINEUP; break;
case VK_RIGHT: wparam = SB_LINEDOWN; break;
default: return;
}
send_message( get_parent(hwnd),
(get_window_long( hwnd, GWL_STYLE ) & SBS_VERT) ? WM_VSCROLL : WM_HSCROLL,
wparam, (LPARAM)hwnd);
}
static int get_scroll_pos(HWND hwnd, int bar) static int get_scroll_pos(HWND hwnd, int bar)
{ {
struct scroll_info *scroll = get_scroll_info_ptr( hwnd, bar, FALSE ); struct scroll_info *scroll = get_scroll_info_ptr( hwnd, bar, FALSE );
...@@ -1155,14 +1181,35 @@ static BOOL set_scroll_range( HWND hwnd, int bar, int min_val, int max_val ) ...@@ -1155,14 +1181,35 @@ static BOOL set_scroll_range( HWND hwnd, int bar, int min_val, int max_val )
return TRUE; return TRUE;
} }
static BOOL get_scroll_range( HWND hwnd, int nBar, int *min, int *max )
{
struct scroll_info *info;
if (!(info = get_scroll_info_ptr( hwnd, nBar, FALSE ))) return FALSE;
if (min) *min = info ? info->minVal : 0;
if (max) *max = info ? info->maxVal : 0;
release_scroll_info_ptr( info );
return TRUE;
}
LRESULT scroll_bar_window_proc( HWND hwnd, UINT msg, WPARAM wparam, LPARAM lparam, BOOL ansi ) LRESULT scroll_bar_window_proc( HWND hwnd, UINT msg, WPARAM wparam, LPARAM lparam, BOOL ansi )
{ {
if (!is_window( hwnd )) return 0;
switch (msg) switch (msg)
{ {
case WM_CREATE: case WM_CREATE:
create_scroll_bar( hwnd, (CREATESTRUCTW *)lparam ); create_scroll_bar( hwnd, (CREATESTRUCTW *)lparam );
return 0; return 0;
case WM_KEYDOWN:
handle_kbd_event( hwnd, wparam, lparam );
return 0;
case WM_KEYUP:
NtUserShowCaret( hwnd );
return 0;
case WM_LBUTTONDBLCLK: case WM_LBUTTONDBLCLK:
case WM_LBUTTONDOWN: case WM_LBUTTONDOWN:
if (get_window_long( hwnd, GWL_STYLE ) & SBS_SIZEGRIP) if (get_window_long( hwnd, GWL_STYLE ) & SBS_SIZEGRIP)
...@@ -1282,7 +1329,47 @@ LRESULT scroll_bar_window_proc( HWND hwnd, UINT msg, WPARAM wparam, LPARAM lpara ...@@ -1282,7 +1329,47 @@ LRESULT scroll_bar_window_proc( HWND hwnd, UINT msg, WPARAM wparam, LPARAM lpara
case SBM_SETSCROLLINFO: case SBM_SETSCROLLINFO:
return set_scroll_info( hwnd, SB_CTL, (SCROLLINFO *)lparam, wparam ); return set_scroll_info( hwnd, SB_CTL, (SCROLLINFO *)lparam, wparam );
case WM_SETCURSOR:
if (get_window_long( hwnd, GWL_STYLE ) & SBS_SIZEGRIP)
{
ULONG_PTR cursor = (get_window_long( hwnd, GWL_EXSTYLE ) & WS_EX_LAYOUTRTL) ?
IDC_SIZENESW : IDC_SIZENWSE;
return (LRESULT)NtUserSetCursor( LoadImageW( 0, (const WCHAR *)cursor, IMAGE_CURSOR,
0, 0, LR_SHARED | LR_DEFAULTSIZE ));
}
return default_window_proc( hwnd, msg, wparam, lparam, ansi );
case SBM_SETPOS:
{
SCROLLINFO info;
info.cbSize = sizeof(info);
info.nPos = wparam;
info.fMask = SIF_POS | SIF_RETURNPREV;
return NtUserSetScrollInfo( hwnd, SB_CTL, &info, lparam );
}
case SBM_GETPOS:
return get_scroll_pos( hwnd, SB_CTL );
case SBM_GETRANGE:
return get_scroll_range( hwnd, SB_CTL, (int *)wparam, (int *)lparam );
case SBM_ENABLE_ARROWS:
return NtUserEnableScrollBar( hwnd, SB_CTL, wparam );
case 0x00e5:
case 0x00e7:
case 0x00e8:
case 0x00ec:
case 0x00ed:
case 0x00ee:
case 0x00ef:
ERR( "unknown Win32 msg %04x wp=%08lx lp=%08lx\n", msg, wparam, lparam );
return 0;
default: default:
if (msg >= WM_USER)
WARN( "unknown msg %04x wp=%08lx lp=%08lx\n", msg, wparam, lparam );
return default_window_proc( hwnd, msg, wparam, lparam, ansi ); return default_window_proc( hwnd, msg, wparam, lparam, ansi );
} }
} }
......
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