mirror of
git://xwords.git.sourceforge.net/gitroot/xwords/xwords
synced 2025-01-16 15:41:16 +01:00
Set aside portion of scrollbar rect above and below it and color that
with focus color when the scrollbar has keyboard focus. This should help users figure out how one-handed nav works. Better would be to override background color of the scrollbar and draw it full-sized, but I havne't figured out how. This is good enough for beta.
This commit is contained in:
parent
e0d73f4cd4
commit
5ba97223f8
4 changed files with 47 additions and 7 deletions
|
@ -1587,11 +1587,23 @@ ce_draw_update( CEDrawCtx* dctx )
|
||||||
}
|
}
|
||||||
} /* ce_drawctxt_update */
|
} /* ce_drawctxt_update */
|
||||||
|
|
||||||
|
static void
|
||||||
|
drawColoredRect( CEDrawCtx* dctx, const RECT* invalR, XP_U16 index )
|
||||||
|
{
|
||||||
|
CEAppGlobals* globals = dctx->globals;
|
||||||
|
FillRect( globals->hdc, invalR, dctx->brushes[index] );
|
||||||
|
}
|
||||||
|
|
||||||
void
|
void
|
||||||
ce_draw_erase( CEDrawCtx* dctx, const RECT* invalR )
|
ce_draw_erase( CEDrawCtx* dctx, const RECT* invalR )
|
||||||
{
|
{
|
||||||
CEAppGlobals* globals = dctx->globals;
|
drawColoredRect( dctx, invalR, CE_BKG_COLOR );
|
||||||
FillRect( globals->hdc, invalR, dctx->brushes[CE_BKG_COLOR] );
|
}
|
||||||
|
|
||||||
|
void
|
||||||
|
ce_draw_focus( CEDrawCtx* dctx, const RECT* invalR )
|
||||||
|
{
|
||||||
|
drawColoredRect( dctx, invalR, CE_FOCUS_COLOR );
|
||||||
}
|
}
|
||||||
|
|
||||||
CEDrawCtx*
|
CEDrawCtx*
|
||||||
|
|
|
@ -27,6 +27,7 @@ typedef struct CEDrawCtx CEDrawCtx;
|
||||||
CEDrawCtx* ce_drawctxt_make( MPFORMAL HWND mainWin, CEAppGlobals* globals );
|
CEDrawCtx* ce_drawctxt_make( MPFORMAL HWND mainWin, CEAppGlobals* globals );
|
||||||
void ce_draw_update( CEDrawCtx* dctx );
|
void ce_draw_update( CEDrawCtx* dctx );
|
||||||
void ce_draw_erase( CEDrawCtx* dctx, const RECT* invalR );
|
void ce_draw_erase( CEDrawCtx* dctx, const RECT* invalR );
|
||||||
|
void ce_draw_focus( CEDrawCtx* dctx, const RECT* invalR );
|
||||||
|
|
||||||
void ce_draw_toStream( const CEDrawCtx* dctx, XWStreamCtxt* stream );
|
void ce_draw_toStream( const CEDrawCtx* dctx, XWStreamCtxt* stream );
|
||||||
void ce_draw_fromStream( CEDrawCtx* dctx, XWStreamCtxt* stream );
|
void ce_draw_fromStream( CEDrawCtx* dctx, XWStreamCtxt* stream );
|
||||||
|
|
|
@ -430,6 +430,19 @@ makeScrollbar( CEAppGlobals* globals, XP_U16 nHidden, XP_U16 xx, XP_U16 yy,
|
||||||
XP_U16 width, XP_U16 height )
|
XP_U16 width, XP_U16 height )
|
||||||
{
|
{
|
||||||
HWND hwndSB;
|
HWND hwndSB;
|
||||||
|
RECT tmp = { .left = xx, .right = xx + width };
|
||||||
|
XP_U16 rectHt = height / 10; /* each focus rect to be 1/10th height */
|
||||||
|
|
||||||
|
tmp.top = yy;
|
||||||
|
tmp.bottom = yy + rectHt;
|
||||||
|
XP_MEMCPY( &globals->scrollRects[0], &tmp, sizeof(globals->scrollRects[0]) );
|
||||||
|
|
||||||
|
tmp.bottom = yy + height;
|
||||||
|
tmp.top = tmp.bottom - rectHt;
|
||||||
|
XP_MEMCPY( &globals->scrollRects[1], &tmp, sizeof(globals->scrollRects[1]) );
|
||||||
|
|
||||||
|
yy += rectHt;
|
||||||
|
height -= rectHt * 2; /* above and below */
|
||||||
|
|
||||||
/* Need to destroy it, or resize it, because board size may be changing
|
/* Need to destroy it, or resize it, because board size may be changing
|
||||||
in case where portrait display's been flipped. */
|
in case where portrait display's been flipped. */
|
||||||
|
@ -442,10 +455,8 @@ makeScrollbar( CEAppGlobals* globals, XP_U16 nHidden, XP_U16 xx, XP_U16 yy,
|
||||||
NULL, // Window text
|
NULL, // Window text
|
||||||
// Window style
|
// Window style
|
||||||
SBS_VERT|WS_VISIBLE|WS_CHILD,
|
SBS_VERT|WS_VISIBLE|WS_CHILD,
|
||||||
xx + SCROLL_SHRINK, yy + 2,
|
xx, yy, width, height, globals->hWnd,
|
||||||
width - SCROLL_SHRINK, height - 4,
|
(HMENU)SCROLLBARID, // The control identifier
|
||||||
globals->hWnd,
|
|
||||||
(HMENU)SCROLLBARID,// The control identifier
|
|
||||||
globals->hInst, // The instance handle
|
globals->hInst, // The instance handle
|
||||||
NULL ); // s'pposed to be NULL
|
NULL ); // s'pposed to be NULL
|
||||||
|
|
||||||
|
@ -1488,13 +1499,23 @@ drawInsidePaint( CEAppGlobals* globals, const RECT* invalR )
|
||||||
|
|
||||||
if ( !!invalR ) {
|
if ( !!invalR ) {
|
||||||
XP_U16 ii;
|
XP_U16 ii;
|
||||||
|
RECT interR;
|
||||||
for ( ii = 0; ii < N_OWNED_RECTS; ++ii ) {
|
for ( ii = 0; ii < N_OWNED_RECTS; ++ii ) {
|
||||||
RECT interR;
|
|
||||||
if ( IntersectRect( &interR, invalR,
|
if ( IntersectRect( &interR, invalR,
|
||||||
&globals->ownedRects[ii] ) ) {
|
&globals->ownedRects[ii] ) ) {
|
||||||
ce_draw_erase( globals->draw, &interR );
|
ce_draw_erase( globals->draw, &interR );
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
for ( ii = 0; ii < VSIZE(globals->scrollRects); ++ii ) {
|
||||||
|
if ( IntersectRect( &interR, invalR,
|
||||||
|
&globals->scrollRects[ii] ) ) {
|
||||||
|
if ( globals->scrollerHasFocus ) {
|
||||||
|
ce_draw_focus( globals->draw, &interR );
|
||||||
|
} else {
|
||||||
|
ce_draw_erase( globals->draw, &interR );
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
board_draw( globals->game.board );
|
board_draw( globals->game.board );
|
||||||
|
@ -2078,10 +2099,14 @@ ceCheckHandleFocusKey( CEAppGlobals* globals, WPARAM wParam, LPARAM lParam,
|
||||||
draw = board_focusChanged( board, order[index], XP_TRUE );
|
draw = board_focusChanged( board, order[index], XP_TRUE );
|
||||||
|
|
||||||
if ( !!globals->scrollHandle ) {
|
if ( !!globals->scrollHandle ) {
|
||||||
|
InvalidateRect( globals->hWnd, &globals->scrollRects[0], TRUE );
|
||||||
|
InvalidateRect( globals->hWnd, &globals->scrollRects[1], TRUE );
|
||||||
if ( order[index] == OBJ_NONE ) {
|
if ( order[index] == OBJ_NONE ) {
|
||||||
SetFocus( globals->scrollHandle );
|
SetFocus( globals->scrollHandle );
|
||||||
|
globals->scrollerHasFocus = XP_TRUE;
|
||||||
} else {
|
} else {
|
||||||
SetFocus( globals->hWnd );
|
SetFocus( globals->hWnd );
|
||||||
|
globals->scrollerHasFocus = XP_FALSE;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -132,6 +132,8 @@ typedef struct CEAppGlobals {
|
||||||
#ifdef CEFEATURE_CANSCROLL
|
#ifdef CEFEATURE_CANSCROLL
|
||||||
HWND scrollHandle;
|
HWND scrollHandle;
|
||||||
WNDPROC oldScrollProc;
|
WNDPROC oldScrollProc;
|
||||||
|
RECT scrollRects[2]; /* above and below the scroller */
|
||||||
|
XP_Bool scrollerHasFocus;
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
CeSocketWrapper* socketWrap;
|
CeSocketWrapper* socketWrap;
|
||||||
|
|
Loading…
Reference in a new issue