mirror of
git://xwords.git.sourceforge.net/gitroot/xwords/xwords
synced 2025-01-16 15:41:16 +01:00
Require two key events to reveal tray and act on a tile; don't treat
divider as wider (to make it easier to tap on) when keyboard being used to select.
This commit is contained in:
parent
1a1beed2f3
commit
eb1f083a19
3 changed files with 27 additions and 18 deletions
|
@ -1269,9 +1269,12 @@ setTrayVisState( BoardCtxt* board, XW_TrayVisState newState )
|
|||
recalculated */
|
||||
figureBoardRect( board ); /* comes before setYOffset since that
|
||||
uses rects to calc scroll */
|
||||
if ( (board->focussed == OBJ_TRAY) && board->focusHasDived ) {
|
||||
board->focusHasDived = XP_FALSE;
|
||||
}
|
||||
|
||||
/* This is sometimes the wrong thing to do, and seems not to be
|
||||
needed at all. */
|
||||
/* if ( (board->focussed == OBJ_TRAY) && board->focusHasDived ) { */
|
||||
/* board->focusHasDived = XP_FALSE; */
|
||||
/* } */
|
||||
invalFocusOwner( board );
|
||||
|
||||
if ( board->boardObscuresTray ) {
|
||||
|
@ -1861,7 +1864,7 @@ handleLikeDown( BoardCtxt* board, BoardObjectType onWhich, XP_U16 x, XP_U16 y )
|
|||
break;
|
||||
|
||||
case OBJ_TRAY:
|
||||
if ( checkRevealTray(board)
|
||||
if ( (board->trayVisState == TRAY_REVEALED)
|
||||
&& !board->selInfo->tradeInProgress ) {
|
||||
result = dragDropStart( board, OBJ_TRAY, x, y ) || result;
|
||||
}
|
||||
|
@ -1892,6 +1895,8 @@ board_handlePenDown( BoardCtxt* board, XP_U16 x, XP_U16 y, XP_Bool* handled )
|
|||
XP_Bool penDidSomething;
|
||||
BoardObjectType onWhich;
|
||||
|
||||
board->srcIsPen = XP_TRUE;
|
||||
|
||||
penDidSomething = pointOnSomething( board, x, y, &onWhich );
|
||||
|
||||
if ( !penDidSomething ) {
|
||||
|
@ -2253,6 +2258,8 @@ board_handleKeyDown( BoardCtxt* board, XP_Key key, XP_Bool* pHandled )
|
|||
#ifdef KEYBOARD_NAV
|
||||
XP_U16 x, y;
|
||||
|
||||
board->srcIsPen = XP_FALSE;
|
||||
|
||||
*pHandled = XP_FALSE;
|
||||
|
||||
if ( key == XP_RETURN_KEY ) {
|
||||
|
|
|
@ -160,6 +160,7 @@ struct BoardCtxt {
|
|||
XP_Bool boardObscuresTray;
|
||||
XP_Bool boardHidesTray;
|
||||
XP_Bool scoreSplitHor;/* how to divide the scoreboard? */
|
||||
XP_Bool srcIsPen; /* We're processing a pen event, not a key event */
|
||||
|
||||
XP_U16 star_row;
|
||||
|
||||
|
|
|
@ -62,8 +62,10 @@ pointToTileIndex( BoardCtxt* board, XP_U16 x, XP_U16 y, XP_Bool* onDividerP )
|
|||
/* The divider rect is narrower and kinda hard to tap on. Let's expand
|
||||
it just for this test */
|
||||
biggerRect = divider;
|
||||
biggerRect.left -= 2;
|
||||
if ( board->srcIsPen ) {
|
||||
biggerRect.left -= 2; /* should be in proportion to tile dims */
|
||||
biggerRect.width += 4;
|
||||
}
|
||||
onDivider = rectContainsPt( &biggerRect, x, y );
|
||||
|
||||
if ( !onDivider ) {
|
||||
|
@ -157,7 +159,7 @@ drawTray( BoardCtxt* board )
|
|||
Tile blank = dict_getBlankTile( dictionary );
|
||||
|
||||
if ( turn >= 0 ) {
|
||||
XP_S16 i; /* which tile slot are we drawing in */
|
||||
XP_S16 ii; /* which tile slot are we drawing in */
|
||||
XP_U16 ddAddedIndx, ddRmvdIndx;
|
||||
XP_U16 numInTray = countTilesToShow( board );
|
||||
XP_Bool isBlank;
|
||||
|
@ -167,10 +169,9 @@ drawTray( BoardCtxt* board )
|
|||
|
||||
/* draw in reverse order so drawing happens after
|
||||
erasing */
|
||||
for ( i = MAX_TRAY_TILES - 1;
|
||||
i >= 0; --i ) {
|
||||
for ( ii = MAX_TRAY_TILES - 1; ii >= 0; --ii ) {
|
||||
CellFlags flags = CELL_NONE;
|
||||
XP_U16 mask = 1 << i;
|
||||
XP_U16 mask = 1 << ii;
|
||||
|
||||
if ( (board->trayInvalBits & mask) == 0 ) {
|
||||
continue;
|
||||
|
@ -180,9 +181,9 @@ drawTray( BoardCtxt* board )
|
|||
flags |= CELL_ISCURSOR;
|
||||
}
|
||||
#endif
|
||||
figureTrayTileRect( board, i, &tileRect );
|
||||
figureTrayTileRect( board, ii, &tileRect );
|
||||
|
||||
if ( i >= numInTray ) {
|
||||
if ( ii >= numInTray ) {
|
||||
draw_drawTile( board->draw, &tileRect, NULL,
|
||||
NULL, -1, flags | CELL_ISEMPTY );
|
||||
} else if ( showFaces ) {
|
||||
|
@ -193,11 +194,11 @@ drawTray( BoardCtxt* board )
|
|||
XP_S16 value;
|
||||
Tile tile;
|
||||
|
||||
if ( ddAddedIndx == i ) {
|
||||
if ( ddAddedIndx == ii ) {
|
||||
dragDropTileInfo( board, &tile, &isBlank );
|
||||
} else {
|
||||
XP_U16 modIndex = i;
|
||||
if ( ddAddedIndx < i ) {
|
||||
XP_U16 modIndex = ii;
|
||||
if ( ddAddedIndx < ii ) {
|
||||
--modIndex;
|
||||
}
|
||||
/* while we're right of the removal area,
|
||||
|
@ -219,10 +220,10 @@ drawTray( BoardCtxt* board )
|
|||
}
|
||||
|
||||
if ( isADrag ) {
|
||||
if ( ddAddedIndx == i ) {
|
||||
if ( ddAddedIndx == ii ) {
|
||||
flags |= CELL_HIGHLIGHT;
|
||||
}
|
||||
} else if ( (traySelBits & (1<<i)) != 0 ) {
|
||||
} else if ( (traySelBits & (1<<ii)) != 0 ) {
|
||||
flags |= CELL_HIGHLIGHT;
|
||||
}
|
||||
if ( isBlank ) {
|
||||
|
|
Loading…
Reference in a new issue