mirror of
git://xwords.git.sourceforge.net/gitroot/xwords/xwords
synced 2024-12-30 10:26:58 +01:00
Bug: tap on hidden tray doesn't reveal it (likely new). Fix by always
reversing hidden tray on giving it focus and by finding tray to be location of pen even when hidden (but only the part not under the board.)
This commit is contained in:
parent
e84a7c7a2d
commit
79ec57be8d
2 changed files with 17 additions and 9 deletions
|
@ -1622,15 +1622,17 @@ invalCell( BoardCtxt* board, XP_U16 col, XP_U16 row )
|
||||||
|
|
||||||
#if defined POINTER_SUPPORT || defined KEYBOARD_NAV
|
#if defined POINTER_SUPPORT || defined KEYBOARD_NAV
|
||||||
XP_Bool
|
XP_Bool
|
||||||
pointOnSomething( BoardCtxt* board, XP_U16 x, XP_U16 y, BoardObjectType* wp )
|
pointOnSomething( BoardCtxt* board, XP_U16 xx, XP_U16 yy, BoardObjectType* wp )
|
||||||
{
|
{
|
||||||
XP_Bool result = XP_TRUE;
|
XP_Bool result = XP_TRUE;
|
||||||
if ( board->trayVisState != TRAY_HIDDEN
|
|
||||||
&& rectContainsPt( &board->trayBounds, x, y ) ) {
|
/* Test the board first in case it overlaps. When tray is visible
|
||||||
*wp = OBJ_TRAY;
|
boardBounds is shortened so it does not overlap. */
|
||||||
} else if ( rectContainsPt( &board->boardBounds, x, y ) ) {
|
if ( rectContainsPt( &board->boardBounds, xx, yy ) ) {
|
||||||
*wp = OBJ_BOARD;
|
*wp = OBJ_BOARD;
|
||||||
} else if ( rectContainsPt( &board->scoreBdBounds, x, y ) ) {
|
} else if ( rectContainsPt( &board->trayBounds, xx, yy ) ) {
|
||||||
|
*wp = OBJ_TRAY;
|
||||||
|
} else if ( rectContainsPt( &board->scoreBdBounds, xx, yy ) ) {
|
||||||
*wp = OBJ_SCORE;
|
*wp = OBJ_SCORE;
|
||||||
} else {
|
} else {
|
||||||
result = XP_FALSE;
|
result = XP_FALSE;
|
||||||
|
@ -2126,7 +2128,7 @@ handlePenUpInternal( BoardCtxt* board, XP_U16 xx, XP_U16 yy, XP_Bool isPen )
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
case OBJ_TRAY:
|
case OBJ_TRAY:
|
||||||
if ( board->trayVisState == TRAY_REVERSED ) {
|
if ( board->trayVisState != TRAY_REVEALED ) {
|
||||||
draw = askRevealTray( board ) || draw;
|
draw = askRevealTray( board ) || draw;
|
||||||
} else {
|
} else {
|
||||||
draw = handlePenUpTray( board, xx, yy ) || draw;
|
draw = handlePenUpTray( board, xx, yy ) || draw;
|
||||||
|
@ -2430,6 +2432,9 @@ board_focusChanged( BoardCtxt* board, BoardObjectType typ, XP_Bool gained )
|
||||||
space. No interdependencies. So handling updating of focus indication
|
space. No interdependencies. So handling updating of focus indication
|
||||||
within the tray drawing process, for example, is ok.
|
within the tray drawing process, for example, is ok.
|
||||||
|
|
||||||
|
Hidden tray: there's no such thing as a hidden, focussed tray. It's
|
||||||
|
made TRAY_REVERSED when it gets focus.
|
||||||
|
|
||||||
Problem: on palm at least take and lost are inverted: you get a take on
|
Problem: on palm at least take and lost are inverted: you get a take on
|
||||||
the new object before a lose on the previous one. So we want to ignore
|
the new object before a lose on the previous one. So we want to ignore
|
||||||
lost events *except* when it's a loss of something we have currently --
|
lost events *except* when it's a loss of something we have currently --
|
||||||
|
@ -2444,6 +2449,9 @@ board_focusChanged( BoardCtxt* board, BoardObjectType typ, XP_Bool gained )
|
||||||
}
|
}
|
||||||
board->focussed = typ;
|
board->focussed = typ;
|
||||||
board->focusHasDived = XP_FALSE;
|
board->focusHasDived = XP_FALSE;
|
||||||
|
if ( (OBJ_TRAY == typ) && (board->trayVisState == TRAY_HIDDEN) ) {
|
||||||
|
setTrayVisState( board, TRAY_REVERSED );
|
||||||
|
}
|
||||||
draw = invalFocusOwner( board ) || draw;
|
draw = invalFocusOwner( board ) || draw;
|
||||||
} else {
|
} else {
|
||||||
/* we're losing it; inval and clear IFF we currently have same focus,
|
/* we're losing it; inval and clear IFF we currently have same focus,
|
||||||
|
@ -2662,7 +2670,7 @@ board_moveCursor( BoardCtxt* board, XP_Key cursorKey, XP_Bool preflightOnly,
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
XP_Bool
|
XP_Bool
|
||||||
rectContainsPt( XP_Rect* rect, XP_S16 x, XP_S16 y )
|
rectContainsPt( const XP_Rect* rect, XP_S16 x, XP_S16 y )
|
||||||
{
|
{
|
||||||
/* 7/4 Made <= into <, etc., because a tap on the right boundary of the
|
/* 7/4 Made <= into <, etc., because a tap on the right boundary of the
|
||||||
board was still mapped onto the board but dividing by scale put it in
|
board was still mapped onto the board but dividing by scale put it in
|
||||||
|
|
|
@ -217,7 +217,7 @@ XP_Bool handlePenUpTray( BoardCtxt* board, XP_U16 x, XP_U16 y );
|
||||||
void drawTray( BoardCtxt* board );
|
void drawTray( BoardCtxt* board );
|
||||||
XP_Bool moveTileToArrowLoc( BoardCtxt* board, XP_U8 index );
|
XP_Bool moveTileToArrowLoc( BoardCtxt* board, XP_U8 index );
|
||||||
XP_U16 indexForBits( XP_U8 bits );
|
XP_U16 indexForBits( XP_U8 bits );
|
||||||
XP_Bool rectContainsPt( XP_Rect* rect1, XP_S16 x, XP_S16 y );
|
XP_Bool rectContainsPt( const XP_Rect* rect1, XP_S16 x, XP_S16 y );
|
||||||
XP_Bool checkRevealTray( BoardCtxt* board );
|
XP_Bool checkRevealTray( BoardCtxt* board );
|
||||||
void figureTrayTileRect( BoardCtxt* board, XP_U16 index, XP_Rect* rect );
|
void figureTrayTileRect( BoardCtxt* board, XP_U16 index, XP_Rect* rect );
|
||||||
XP_Bool rectsIntersect( const XP_Rect* rect1, const XP_Rect* rect2 );
|
XP_Bool rectsIntersect( const XP_Rect* rect1, const XP_Rect* rect2 );
|
||||||
|
|
Loading…
Reference in a new issue