back out 2245: having scrollbar be focusable is a better way of allowing scrolling than overloading cursor movement; scroll cursor onscreen when diving and it is off

This commit is contained in:
ehouse 2008-10-20 02:23:17 +00:00
parent afbb5ed2fe
commit c48f836fe7

View file

@ -2390,6 +2390,7 @@ invalFocusOwner( BoardCtxt* board )
if ( board->focusHasDived ) { if ( board->focusHasDived ) {
BdCursorLoc loc = pti->bdCursor; BdCursorLoc loc = pti->bdCursor;
invalCell( board, loc.col, loc.row ); invalCell( board, loc.col, loc.row );
checkScrollCell( board, loc.col, loc.row );
} else { } else {
#ifdef PERIMETER_FOCUS #ifdef PERIMETER_FOCUS
invalPerimeter( board ); invalPerimeter( board );
@ -2606,64 +2607,28 @@ stripAlt( XP_Key key, XP_Bool* wasAlt )
return key; return key;
} /* stripAlt */ } /* stripAlt */
static XP_Bool
scrollTrumpsMove( const BoardCtxt* board, XP_Key cursorKey, XP_S16* moveBy )
{
XP_Bool scroll = XP_FALSE;
if ( XP_CURSOR_KEY_DOWN == cursorKey ) {
scroll = (board->lastVisibleRow+1) < model_numRows( board->model );
if ( scroll ) {
*moveBy = -1;
}
} else if ( XP_CURSOR_KEY_UP == cursorKey ) {
scroll = board->yOffset > 0;
if ( scroll ) {
*moveBy = 1;
}
}
return scroll;
}
static XP_Bool static XP_Bool
board_moveCursor( BoardCtxt* board, XP_Key cursorKey, XP_Bool preflightOnly, board_moveCursor( BoardCtxt* board, XP_Key cursorKey, XP_Bool preflightOnly,
XP_Bool* up ) XP_Bool* up )
{ {
PerTurnInfo* pti = board->selInfo; PerTurnInfo* pti = board->selInfo;
BdCursorLoc loc; BdCursorLoc loc = pti->bdCursor;
XP_S16 moveBy; XP_U16 col = loc.col;
XP_U16 row = loc.row;
XP_Bool changed; XP_Bool changed;
XP_Bool needMove = XP_FALSE;
XP_Bool altSet; XP_Bool altSet;
cursorKey = stripAlt( cursorKey, &altSet ); cursorKey = stripAlt( cursorKey, &altSet );
changed = !preflightOnly changed = figureNextLoc( board, cursorKey, XP_FALSE, altSet,
&& scrollTrumpsMove( board, cursorKey, &moveBy ); &col, &row, up );
if ( changed ) { if ( changed && !preflightOnly ) {
if ( adjustYOffset( board, moveBy ) ) { invalCell( board, loc.col, loc.row );
/* need to move the cursor too? */ invalCell( board, col, row );
XP_Rect ignore; loc.col = col;
loc = pti->bdCursor; loc.row = row;
needMove = !getCellRect( board, loc.col, loc.row, &ignore ); pti->bdCursor = loc;
} checkScrollCell( board, col, row );
}
/* PENDING: Is it a problem that needMove will only get set if
preflightOnly is false? */
if ( !changed || needMove ) {
XP_U16 col, row;
loc = pti->bdCursor;
col = loc.col;
row = loc.row;
changed = figureNextLoc( board, cursorKey, XP_FALSE, altSet,
&col, &row, up );
if ( changed && !preflightOnly ) {
invalCell( board, loc.col, loc.row );
invalCell( board, col, row );
loc.col = col;
loc.row = row;
pti->bdCursor = loc;
}
} }
return changed; return changed;
} /* board_moveCursor */ } /* board_moveCursor */