provide callback for most recent score; return key on hidden tray

attempts to reveal; add focus obj to saved state.
This commit is contained in:
ehouse 2005-01-22 19:51:48 +00:00
parent 4ac01e29a4
commit 7bfcd9d161

View file

@ -132,7 +132,7 @@ board_make( MPFORMAL ModelCtxt* model, ServerCtxt* server, DrawCtx* draw,
result->trayVisState = TRAY_HIDDEN; result->trayVisState = TRAY_HIDDEN;
result->star_row = model_numRows(model) / 2; result->star_row = (XP_U16)(model_numRows(model) / 2);
/* could just pass in invalCell.... PENDING(eeh) */ /* could just pass in invalCell.... PENDING(eeh) */
model_setBoardListener( model, boardCellChanged, result ); model_setBoardListener( model, boardCellChanged, result );
@ -179,6 +179,9 @@ board_makeFromStream( MPFORMAL XWStreamCtxt* stream, ModelCtxt* model,
board->gameOver = (XP_Bool)stream_getBits( stream, 1 ); board->gameOver = (XP_Bool)stream_getBits( stream, 1 );
board->showColors = (XP_Bool)stream_getBits( stream, 1 ); board->showColors = (XP_Bool)stream_getBits( stream, 1 );
board->showCellValues = (XP_Bool)stream_getBits( stream, 1 ); board->showCellValues = (XP_Bool)stream_getBits( stream, 1 );
#ifdef KEYBOARD_NAV
board->focussed = (BoardObjectType)stream_getBits( stream, 2 );
#endif
XP_ASSERT( !!server ); XP_ASSERT( !!server );
@ -226,6 +229,9 @@ board_writeToStream( BoardCtxt* board, XWStreamCtxt* stream )
stream_putBits( stream, 1, board->gameOver ); stream_putBits( stream, 1, board->gameOver );
stream_putBits( stream, 1, board->showColors ); stream_putBits( stream, 1, board->showColors );
stream_putBits( stream, 1, board->showCellValues ); stream_putBits( stream, 1, board->showCellValues );
#ifdef KEYBOARD_NAV
stream_putBits( stream, 2, board->focussed );
#endif
XP_ASSERT( !!board->server ); XP_ASSERT( !!board->server );
nPlayers = board->gi->nPlayers; nPlayers = board->gi->nPlayers;
@ -275,7 +281,7 @@ board_reset( BoardCtxt* board )
XP_MEMSET( &board->boardArrow, 0, sizeof(board->boardArrow) ); XP_MEMSET( &board->boardArrow, 0, sizeof(board->boardArrow) );
board->gameOver = XP_FALSE; board->gameOver = XP_FALSE;
board->selPlayer = 0; board->selPlayer = 0;
board->star_row = model_numRows(board->model) / 2; board->star_row = (XP_U16)(model_numRows(board->model) / 2);
newState = board->boardObscuresTray? TRAY_HIDDEN:TRAY_REVERSED; newState = board->boardObscuresTray? TRAY_HIDDEN:TRAY_REVERSED;
setTrayVisState( board, newState ); setTrayVisState( board, newState );
@ -298,8 +304,8 @@ board_setPos( BoardCtxt* board, XP_U16 left, XP_U16 top,
void void
board_setScoreboardLoc( BoardCtxt* board, XP_U16 scoreLeft, XP_U16 scoreTop, board_setScoreboardLoc( BoardCtxt* board, XP_U16 scoreLeft, XP_U16 scoreTop,
XP_U16 scoreWidth, XP_U16 scoreHeight, XP_U16 scoreWidth, XP_U16 scoreHeight,
XP_Bool divideHorizontally ) XP_Bool divideHorizontally )
{ {
board->scoreBdBounds.left = scoreLeft; board->scoreBdBounds.left = scoreLeft;
board->scoreBdBounds.top = scoreTop; board->scoreBdBounds.top = scoreTop;
@ -1083,6 +1089,15 @@ drawTimer( BoardCtxt* board )
} }
} /* drawTimer */ } /* drawTimer */
static XP_Bool
board_ScoreCallback( void* closure, XP_S16 player, XP_UCHAR* expl,
XP_U16* explLen)
{
ModelCtxt* model = (ModelCtxt*)closure;
return model_getPlayersLastScore( model, player,
expl, explLen );
} /* board_ScoreCallback */
typedef struct DrawScoreData { typedef struct DrawScoreData {
DrawScoreInfo dsi; DrawScoreInfo dsi;
XP_U16 height; XP_U16 height;
@ -1145,6 +1160,10 @@ drawScoreBoard( BoardCtxt* board )
for ( dp = datum, i = 0; i < nPlayers; ++i, ++dp ) { for ( dp = datum, i = 0; i < nPlayers; ++i, ++dp ) {
LocalPlayer* lp = &board->gi->players[i]; LocalPlayer* lp = &board->gi->players[i];
/* This is a hack! */
dp->dsi.lsc = board_ScoreCallback;
dp->dsi.lscClosure = model;
dp->dsi.score = scores[i]; dp->dsi.score = scores[i];
dp->dsi.isTurn = (i == curTurn); dp->dsi.isTurn = (i == curTurn);
dp->dsi.name = emptyStringIfNull(lp->name); dp->dsi.name = emptyStringIfNull(lp->name);
@ -2562,7 +2581,11 @@ board_handleKey( BoardCtxt* board, XP_Key key )
case XP_RETURN_KEY: case XP_RETURN_KEY:
if ( board->focussed == OBJ_TRAY ) { if ( board->focussed == OBJ_TRAY ) {
result = tray_keyAction( board ); if ( trayVisible ) {
result = tray_keyAction( board );
} else {
result = askRevealTray( board );
}
} else if ( board->focussed == OBJ_BOARD ) { } else if ( board->focussed == OBJ_BOARD ) {
/* mimic pen-down/pen-up on cursor */ /* mimic pen-down/pen-up on cursor */
BdCursorLoc loc = board->bdCursor[board->selPlayer]; BdCursorLoc loc = board->bdCursor[board->selPlayer];