Commit 9a58351f authored by Francois Methot's avatar Francois Methot Committed by Alexandre Julliard

Added support of blinking thumb as found in Windows scrollbar.

parent d1082dca
...@@ -816,6 +816,18 @@ void SCROLL_DrawScrollBar( HWND hwnd, HDC hdc, INT nBar, ...@@ -816,6 +816,18 @@ void SCROLL_DrawScrollBar( HWND hwnd, HDC hdc, INT nBar,
(SCROLL_TrackingBar == nBar)) (SCROLL_TrackingBar == nBar))
SCROLL_DrawMovingThumb( hdc, &rect, vertical, arrowSize, thumbSize ); SCROLL_DrawMovingThumb( hdc, &rect, vertical, arrowSize, thumbSize );
if(hwnd==GetFocus()) /* if scroll bar has focus, reposition the caret*/
{
if (!vertical)
{
SetCaretPos(thumbPos+1, rect.top+1);
}
else
{
SetCaretPos(rect.top+1, thumbPos+1);
}
}
END: END:
WIN_ReleaseWndPtr(wndPtr); WIN_ReleaseWndPtr(wndPtr);
} }
...@@ -907,14 +919,15 @@ void SCROLL_HandleScrollEvent( HWND hwnd, INT nBar, UINT msg, POINT pt) ...@@ -907,14 +919,15 @@ void SCROLL_HandleScrollEvent( HWND hwnd, INT nBar, UINT msg, POINT pt)
switch(msg) switch(msg)
{ {
case WM_LBUTTONDOWN: /* Initialise mouse tracking */ case WM_LBUTTONDOWN: /* Initialise mouse tracking */
SCROLL_trackVertical = vertical; HideCaret(hwnd); /* hide caret while holding down LBUTTON*/
SCROLL_trackVertical = vertical;
SCROLL_trackHitTest = hittest = SCROLL_HitTest( hwnd, nBar, pt, FALSE ); SCROLL_trackHitTest = hittest = SCROLL_HitTest( hwnd, nBar, pt, FALSE );
lastClickPos = vertical ? (pt.y - rect.top) : (pt.x - rect.left); lastClickPos = vertical ? (pt.y - rect.top) : (pt.x - rect.left);
lastMousePos = lastClickPos; lastMousePos = lastClickPos;
trackThumbPos = thumbPos; trackThumbPos = thumbPos;
prevPt = pt; prevPt = pt;
SetCapture( hwnd ); SetCapture( hwnd );
if (nBar == SB_CTL) SetFocus( hwnd ); if (nBar == SB_CTL && (GetWindowLongA(hwnd, GWL_STYLE) & WS_TABSTOP)) SetFocus( hwnd );
break; break;
case WM_MOUSEMOVE: case WM_MOUSEMOVE:
...@@ -925,6 +938,8 @@ void SCROLL_HandleScrollEvent( HWND hwnd, INT nBar, UINT msg, POINT pt) ...@@ -925,6 +938,8 @@ void SCROLL_HandleScrollEvent( HWND hwnd, INT nBar, UINT msg, POINT pt)
case WM_LBUTTONUP: case WM_LBUTTONUP:
hittest = SCROLL_NOWHERE; hittest = SCROLL_NOWHERE;
ReleaseCapture(); ReleaseCapture();
/* if scrollbar has focus, show back caret */
if (hwnd==GetFocus()) ShowCaret(hwnd);
break; break;
case WM_SYSTIMER: case WM_SYSTIMER:
...@@ -1142,10 +1157,60 @@ LRESULT WINAPI ScrollBarWndProc( HWND hwnd, UINT message, WPARAM wParam, ...@@ -1142,10 +1157,60 @@ LRESULT WINAPI ScrollBarWndProc( HWND hwnd, UINT message, WPARAM wParam,
} }
break; break;
/* if key event is received, the scrollbar has the focus*/
case WM_KEYDOWN: case WM_KEYDOWN:
HideCaret(hwnd); /*hide caret to prevent flicker*/
SCROLL_HandleKbdEvent( hwnd, wParam ); SCROLL_HandleKbdEvent( hwnd, wParam );
break; break;
case WM_KEYUP:
ShowCaret(hwnd);
break;
case WM_SETFOCUS:
{
/* Create a caret when a ScrollBar get focus*/
RECT rect;
int arrowSize, thumbSize, thumbPos, vertical;
if(hwnd==GetFocus())
{
vertical = SCROLL_GetScrollBarRect( hwnd, SB_CTL, &rect,
&arrowSize, &thumbSize, &thumbPos );
if (!vertical)
{
CreateCaret(hwnd,1, thumbSize-2, rect.bottom-rect.top-2);
SetCaretPos(thumbPos+1, rect.top+1);
}
else
{
CreateCaret(hwnd,1, rect.right-rect.left-2,thumbSize-2);
SetCaretPos(rect.top+1, thumbPos+1);
}
ShowCaret(hwnd);
}
}
break;
case WM_KILLFOCUS:
{
RECT rect;
int arrowSize, thumbSize, thumbPos, vertical;
vertical = SCROLL_GetScrollBarRect( hwnd, SB_CTL, &rect,&arrowSize, &thumbSize, &thumbPos );
if (!vertical){
rect.left=thumbPos+1;
rect.right=rect.left+thumbSize;
}
else
{
rect.top=thumbPos+1;
rect.bottom=rect.top+thumbSize;
}
HideCaret(hwnd);
InvalidateRect(hwnd,&rect,0);
DestroyCaret();
}
break;
case WM_ERASEBKGND: case WM_ERASEBKGND:
return 1; return 1;
......
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