Remove old focus-change callback; use extended handleKey API to allow

Palm to own all top-level focus change decisions (in accord with fnav
resource)
This commit is contained in:
ehouse 2006-11-14 06:54:14 +00:00
parent 427c433e2a
commit 56f64f6f46

View file

@ -157,10 +157,6 @@ static MemHandle findXWPrefsRsrc( PalmAppGlobals* globals, UInt32 resType,
static void palm_util_engineStarting( XW_UtilCtxt* uc, XP_U16 nBlanks ); static void palm_util_engineStarting( XW_UtilCtxt* uc, XP_U16 nBlanks );
static void palm_util_engineStopping( XW_UtilCtxt* uc ); static void palm_util_engineStopping( XW_UtilCtxt* uc );
#endif #endif
#ifdef XWFEATURE_FIVEWAY
static void palm_util_notifyFocusChange( XW_UtilCtxt* uc, BoardObjectType cur,
XP_Key key, BoardObjectType* next );
#endif
static void initAndStartBoard( PalmAppGlobals* globals, XP_Bool newGame ); static void initAndStartBoard( PalmAppGlobals* globals, XP_Bool newGame );
@ -625,9 +621,6 @@ initUtilFuncs( PalmAppGlobals* globals )
vtable->m_util_engineStarting = palm_util_engineStarting; vtable->m_util_engineStarting = palm_util_engineStarting;
vtable->m_util_engineStopping = palm_util_engineStopping; vtable->m_util_engineStopping = palm_util_engineStopping;
#endif #endif
#ifdef XWFEATURE_FIVEWAY
vtable->m_util_notifyFocusChange = palm_util_notifyFocusChange;
#endif
} /* initUtilFuncs */ } /* initUtilFuncs */
#ifdef COLOR_SUPPORT #ifdef COLOR_SUPPORT
@ -2057,6 +2050,7 @@ handleFocusEvent( PalmAppGlobals* globals, const EventType* event,
XP_Bool redraw = XP_FALSE; XP_Bool redraw = XP_FALSE;
XP_U16 objectID = event->data.frmObjectFocusTake.objectID; XP_U16 objectID = event->data.frmObjectFocusTake.objectID;
XP_Bool take; XP_Bool take;
XP_Bool drawBoard = XP_FALSE;
XP_ASSERT( &event->data.frmObjectFocusTake.objectID XP_ASSERT( &event->data.frmObjectFocusTake.objectID
== &event->data.frmObjectFocusLost.objectID ); == &event->data.frmObjectFocusLost.objectID );
@ -2070,6 +2064,7 @@ handleFocusEvent( PalmAppGlobals* globals, const EventType* event,
case XW_SCOREBOARD_GADGET_ID: case XW_SCOREBOARD_GADGET_ID:
case XW_TRAY_GADGET_ID: case XW_TRAY_GADGET_ID:
handled = XP_TRUE; handled = XP_TRUE;
drawBoard = !take;
break; break;
case XW_MAIN_DONE_BUTTON_ID: case XW_MAIN_DONE_BUTTON_ID:
@ -2082,7 +2077,8 @@ handleFocusEvent( PalmAppGlobals* globals, const EventType* event,
if ( handled ) { if ( handled ) {
BoardObjectType typ = (objectID - XW_BOARD_GADGET_ID) + OBJ_BOARD; BoardObjectType typ = (objectID - XW_BOARD_GADGET_ID) + OBJ_BOARD;
*drawP = board_focusChanged( globals->game.board, typ, take ); drawBoard = board_focusChanged( globals->game.board, typ, take )
|| drawBoard;
if ( take ) { if ( take ) {
FrmSetFocus( globals->mainForm, FrmSetFocus( globals->mainForm,
FrmGetObjectIndex( globals->mainForm, objectID ) ); FrmGetObjectIndex( globals->mainForm, objectID ) );
@ -2093,20 +2089,10 @@ handleFocusEvent( PalmAppGlobals* globals, const EventType* event,
TRAY_BUTTONS_BMP_RES_ID, XP_FALSE ); TRAY_BUTTONS_BMP_RES_ID, XP_FALSE );
} }
*drawP = drawBoard;
return handled; return handled;
} /* handleFocusEvent */ } /* handleFocusEvent */
static void
checkSetFocus( PalmAppGlobals* globals, BoardObjectType typ )
{
if ( globals->hasFiveWay ) {
XP_U16 objectID = XW_BOARD_GADGET_ID + (typ - OBJ_BOARD);
/* XP_LOGF( "%s: FrmSetFocus(%s)", __FUNCTION__, frmObjId_2str(objectID) ); */
FrmSetFocus( globals->mainForm,
FrmGetObjectIndex( globals->mainForm, objectID ) );
}
}
#endif #endif
/***************************************************************************** /*****************************************************************************
@ -2115,8 +2101,8 @@ checkSetFocus( PalmAppGlobals* globals, BoardObjectType typ )
static Boolean static Boolean
mainViewHandleEvent( EventPtr event ) mainViewHandleEvent( EventPtr event )
{ {
Boolean handled = true; XP_Bool handled = XP_TRUE;
Boolean draw = false; XP_Bool draw = XP_FALSE;
Boolean erase; Boolean erase;
#if defined CURSOR_MOVEMENT && defined DEBUG #if defined CURSOR_MOVEMENT && defined DEBUG
CursorDirection cursorDir; CursorDirection cursorDir;
@ -2574,17 +2560,19 @@ mainViewHandleEvent( EventPtr event )
let's give the board two shots at each char, one lower case let's give the board two shots at each char, one lower case
and another upper. */ and another upper. */
if ( ch < 255 && ch > ' ' ) { if ( ch < 255 && ch > ' ' ) {
draw = board_handleKey( globals->game.board, ch ); draw = board_handleKey( globals->game.board, ch, &handled );
if ( !draw && ch >= 'a' ) { if ( !handled && ch >= 'a' ) {
draw = board_handleKey( globals->game.board, draw = board_handleKey( globals->game.board,
ch - ('a' - 'A') ); ch - ('a' - 'A'), &handled );
} }
} }
} }
if ( xpkey != XP_KEY_NONE ) { if ( xpkey != XP_KEY_NONE ) {
draw = board_handleKey( globals->game.board, xpkey ); draw = board_handleKey( globals->game.board, xpkey, &handled );
} else {
/* remove this and break focus drilldown. Why? */
handled = draw;
} }
handled = draw;
} }
break; break;
@ -3701,72 +3689,3 @@ palm_util_engineStopping( XW_UtilCtxt* uc )
} }
} /* palm_util_engineStopping */ } /* palm_util_engineStopping */
#endif #endif
#ifdef XWFEATURE_FIVEWAY
static void
palm_util_notifyFocusChange( XW_UtilCtxt* uc, BoardObjectType cur,
XP_Key key, BoardObjectType* nextP )
{
PalmAppGlobals* globals = (PalmAppGlobals*)uc->closure;
if ( !globals->hasFiveWay ) {
*nextP = cur;
} else {
XP_U16 nextID = 0;
BoardObjectType nxt = OBJ_NONE;
XP_Bool forward = key == XP_CURSOR_KEY_DOWN
|| key == XP_CURSOR_KEY_RIGHT;
XW_TrayVisState state;
state = board_getTrayVisState( globals->game.board );
switch( cur ) {
case OBJ_NONE: /* hi compiler */
XP_ASSERT(0);
break;
case OBJ_SCORE:
if ( forward ) {
nxt = OBJ_BOARD;
} else {
nextID = state == TRAY_REVEALED?
XW_MAIN_DONE_BUTTON_ID : XW_MAIN_HIDE_BUTTON_ID;
}
break;
case OBJ_BOARD:
if ( forward ) {
nextID = XW_MAIN_FLIP_BUTTON_ID;
} else {
nxt = OBJ_SCORE;
}
break;
case OBJ_TRAY:
if ( forward ) {
nextID = XW_MAIN_HIDE_BUTTON_ID;
} else {
nextID = state == TRAY_REVEALED?
XW_MAIN_HINT_BUTTON_ID : XW_MAIN_VALUE_BUTTON_ID;
}
break;
}
*nextP = nxt;
if ( nxt != OBJ_NONE ) {
XP_ASSERT( nextID == 0 );
checkSetFocus( globals, nxt );
} else if ( nextID != 0 ) {
FormPtr form = globals->mainForm;
RectangleType rect;
XP_U16 index = FrmGetObjectIndex( form, nextID );
FrmSetFocus( form, index );
getObjectBounds( nextID, &rect );
(void)HsNavDrawFocusRing( form, nextID, 0, &rect,
hsNavFocusRingStyleObjectTypeDefault,
false );
} else {
XP_ASSERT(0);
}
}
} /* palm_util_notifyFocusChange */
#endif