add five-way support for Tungstens; don't move cursor when keys are

meant for menu; redraw after hiding miniwindow when OS brings up
dialog;
This commit is contained in:
ehouse 2007-01-18 05:49:54 +00:00
parent d22f65b78b
commit e10f6d2163
3 changed files with 96 additions and 29 deletions

View file

@ -168,6 +168,7 @@ INCLUDES += -I/usr/local/share/palmdev/sdk-5r3/include/Extensions/Bluetooth
endif endif
XWFEATURE_FIVEWAY = -DXWFEATURE_FIVEWAY -DKEYBOARD_NAV XWFEATURE_FIVEWAY = -DXWFEATURE_FIVEWAY -DKEYBOARD_NAV
XWFEATURE_FIVEWAY += -DDO_TUNGSTEN_FIVEWAY
ifneq (x$(XWFEATURE_FIVEWAY)x, xx) ifneq (x$(XWFEATURE_FIVEWAY)x, xx)
INCLUDES += -I/usr/local/share/palmdev/Handspring5 INCLUDES += -I/usr/local/share/palmdev/Handspring5

View file

@ -924,10 +924,10 @@ initHighResGlobals( PalmAppGlobals* globals )
globals->oneDotFiveAvail = ( err == errNone && vers >= 5 ); globals->oneDotFiveAvail = ( err == errNone && vers >= 5 );
err = FtrGet( sysFtrCreator, sysFtrNumUIHardwareFlags, &vers ); err = FtrGet( sysFtrCreator, sysFtrNumUIHardwareFlags, &vers );
globals->hasKeyboard = ( (err == errNone) globals->hasTreoKeyboard = ( (err == errNone)
&& ((vers & sysFtrNumUIHardwareHasKbd) != 0) ); && ((vers & sysFtrNumUIHardwareHasKbd) != 0) );
#ifdef XWFEATURE_FIVEWAY #ifdef XWFEATURE_FIVEWAY
globals->hasFiveWay = ( (err == errNone) globals->hasTreoFiveWay = ( (err == errNone)
&& ((vers & sysFtrNumUIHardwareHas5Way) != 0) ); && ((vers & sysFtrNumUIHardwareHas5Way) != 0) );
#endif #endif
@ -1734,7 +1734,7 @@ drawFormButtons( PalmAppGlobals* globals )
} }
#ifdef XWFEATURE_FIVEWAY #ifdef XWFEATURE_FIVEWAY
if ( globals->hasFiveWay ) { if ( globals->hasTreoFiveWay ) {
drawFocusRingOnGadget( XW_MAIN_DONE_BUTTON_ID, drawFocusRingOnGadget( XW_MAIN_DONE_BUTTON_ID,
XW_MAIN_HIDE_BUTTON_ID ); XW_MAIN_HIDE_BUTTON_ID );
} }
@ -2121,6 +2121,26 @@ handleFocusEvent( PalmAppGlobals* globals, const EventType* event,
} /* handleFocusEvent */ } /* handleFocusEvent */
#endif #endif
#ifdef DO_TUNGSTEN_FIVEWAY
/* These are supposed to be defined in some SDK headers but I can't find 'em,
* and if I could they're obscure enough that I wouldn't want the build to
* depend on 'em since they're copyrighted and I couldn't distribute. */
# define vchrNavChange (vchrPalmMin + 3)
# define navBitUp 0x0001
# define navBitDown 0x0002
# define navBitLeft 0x0004
# define navBitRight 0x0008
# define navBitSelect 0x0010
# define navBitsAll 0x001F
# define navChangeUp 0x0100
# define navChangeDown 0x0200
# define navChangeLeft 0x0400
# define navChangeRight 0x0800
# define navChangeSelect 0x1000
# define navChangeBitsAll 0x1F00
#endif
static XP_Bool static XP_Bool
handleKeyEvent( PalmAppGlobals* globals, const EventType* event, handleKeyEvent( PalmAppGlobals* globals, const EventType* event,
XP_Bool* handledP ) XP_Bool* handledP )
@ -2133,31 +2153,54 @@ handleKeyEvent( PalmAppGlobals* globals, const EventType* event,
XP_Key xpkey = XP_KEY_NONE; XP_Key xpkey = XP_KEY_NONE;
XP_Bool handled = XP_FALSE; XP_Bool handled = XP_FALSE;
XP_Bool altOn = (event->data.keyUp.modifiers & shiftKeyMask) != 0; XP_Bool altOn = (event->data.keyUp.modifiers & shiftKeyMask) != 0;
XP_Bool treatAsUp = !globals->hasKeyboard || (event->eType == keyUpEvent); XP_Bool treatAsUp = !globals->hasTreoKeyboard
|| (event->eType == keyUpEvent);
XP_U16 keyCode = event->data.keyDown.keyCode;
Int16 chr; Int16 chr;
XP_Bool (*handler)( BoardCtxt*, XP_Key, XP_Bool* ); XP_Bool (*handler)( BoardCtxt*, XP_Key, XP_Bool* );
BoardCtxt* board = globals->game.board;
#ifdef DO_TUNGSTEN_FIVEWAY
XP_S16 incr = 0;
if ( !globals->hasTreoKeyboard
&& (event->data.keyDown.chr == vchrNavChange) ) {
if ( (keyCode & (/* navBitUp | */navChangeUp )) != 0 ) {
keyCode = vchrRockerUp;
incr = -1;
} else if ( (keyCode & (/* navBitDown | */navChangeDown )) != 0 ) {
keyCode = vchrRockerDown;
incr = 1;
} else if ( (keyCode & (navBitLeft /* |navChangeLeft */ )) != 0 ) {
keyCode = vchrRockerLeft;
incr = -1;
} else if ( (keyCode & ( navBitRight /* | navChangeRight */ )) != 0 ) {
keyCode = vchrRockerRight;
incr = 1;
} else if ( (keyCode & (navBitSelect /* | navChangeSelect */ )) != 0 ) {
keyCode = vchrRockerCenter;
}
}
#endif
XP_ASSERT( OFFSET_OF(EventType, data.keyUp.modifiers) XP_ASSERT( OFFSET_OF(EventType, data.keyUp.modifiers)
== OFFSET_OF(EventType, data.keyDown.modifiers) ); == OFFSET_OF(EventType, data.keyDown.modifiers) );
XP_ASSERT( OFFSET_OF(EventType, data.keyUp.keyCode) XP_ASSERT( OFFSET_OF(EventType, data.keyUp.keyCode)
== OFFSET_OF(EventType, data.keyDown.keyCode) ); == OFFSET_OF(EventType, data.keyDown.keyCode) );
if ( treatAsUp ) { if ( !globals->hasTreoKeyboard ) {
handler = board_handleKey;
} else if ( event->eType == keyUpEvent ) {
handler = board_handleKeyUp; handler = board_handleKeyUp;
globals->lastKeyDown = XP_KEY_NONE; globals->lastKeyDown = XP_KEY_NONE;
} else if ( globals->hasKeyboard ) { } else if ( (event->data.keyDown.modifiers & autoRepeatKeyMask) != 0 ) {
if ( (event->data.keyDown.modifiers & autoRepeatKeyMask) != 0 ) {
handler = board_handleKeyRepeat; handler = board_handleKeyRepeat;
} else { } else {
handler = board_handleKeyDown; handler = board_handleKeyDown;
XP_ASSERT( globals->lastKeyDown == XP_KEY_NONE ); XP_ASSERT( globals->lastKeyDown == XP_KEY_NONE );
globals->lastKeyDown = event->data.keyDown.keyCode; globals->lastKeyDown = event->data.keyDown.keyCode;
} }
} else {
handler = NULL;
}
switch ( event->data.keyDown.keyCode ) { switch ( keyCode ) {
#ifdef XWFEATURE_FIVEWAY #ifdef XWFEATURE_FIVEWAY
case vchrRockerCenter: case vchrRockerCenter:
xpkey = XP_RETURN_KEY; xpkey = XP_RETURN_KEY;
@ -2186,11 +2229,9 @@ handleKeyEvent( PalmAppGlobals* globals, const EventType* 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 ( chr < 255 && chr > ' ' ) { if ( chr < 255 && chr > ' ' ) {
draw = !!handler && (*handler)( globals->game.board, draw = !!handler && (*handler)( board, chr, &handled );
chr, &handled );
if ( !handled && chr >= 'a' ) { if ( !handled && chr >= 'a' ) {
draw = !!handler && (*handler)( globals->game.board, draw = !!handler && (*handler)( board, chr - ('a' - 'A'),
chr - ('a' - 'A'),
&handled ); &handled );
} }
} else { } else {
@ -2203,20 +2244,42 @@ handleKeyEvent( PalmAppGlobals* globals, const EventType* event,
break; break;
case backspaceChr: case backspaceChr:
xpkey = XP_CURSOR_KEY_DEL; xpkey = XP_CURSOR_KEY_DEL;
break;
case chrSpace:
xpkey = XP_RAISEFOCUS_KEY;
break;
} }
} }
} }
if ( xpkey != XP_KEY_NONE ) { if ( xpkey != XP_KEY_NONE ) {
XP_ASSERT( !!handler ); XP_ASSERT( !!handler );
draw = (*handler)( globals->game.board, xpkey, &handled ); draw = (*handler)( board, xpkey, &handled );
/* If handled comes back false yet something changed (draw), /* If handled comes back false yet something changed (draw),
we'll be getting another event shortly. Put the draw off we'll be getting another event shortly. Put the draw off
until then so we don't flash the tray focussed then not. This until then so we don't flash the tray focussed then not. This
is a hack, but I can't think of a way to integrate it into is a hack, but I can't think of a way to integrate it into
board.c logic without making too many palm-centric assumptions board.c logic without making too many palm-centric assumptions
there. */ there. */
if ( draw && !handled ) { if ( 0 ) {
#ifdef DO_TUNGSTEN_FIVEWAY
} else if ( !globals->hasTreoKeyboard && !handled && (incr != 0) ) {
/* order'll be different if scoreboard is vertical */
BoardObjectType typs[] = { OBJ_SCORE, OBJ_BOARD, OBJ_TRAY };
BoardObjectType nxt = board_getFocusOwner( board );
XP_U16 indx = 0;
if ( nxt != OBJ_NONE ) {
for ( ; indx < sizeof(typs)/sizeof(typs[0]); ++indx ){
if ( nxt == typs[indx] ) {
indx = (indx + (sizeof(typs)/sizeof(typs[0]) + incr));
indx %= sizeof(typs)/sizeof(typs[0]);
break;
}
}
}
draw = board_focusChanged( board, typs[indx], XP_TRUE ) || draw;
#endif
} else if ( draw && !handled ) {
draw = XP_FALSE; draw = XP_FALSE;
} }
} else { } else {
@ -2340,7 +2403,7 @@ mainViewHandleEvent( EventPtr event )
event.eType = keyUpEvent; event.eType = keyUpEvent;
event.data.keyUp.chr = event.data.keyUp.keyCode event.data.keyUp.chr = event.data.keyUp.keyCode
= globals->lastKeyDown; = globals->lastKeyDown;
(void)handleKeyEvent( globals, &event, &ignore ); draw = handleKeyEvent( globals, &event, &ignore );
} }
break; break;
@ -2660,14 +2723,17 @@ mainViewHandleEvent( EventPtr event )
#ifdef XWFEATURE_FIVEWAY #ifdef XWFEATURE_FIVEWAY
case frmObjectFocusTakeEvent: case frmObjectFocusTakeEvent:
case frmObjectFocusLostEvent: case frmObjectFocusLostEvent:
handled = globals->hasFiveWay handled = globals->hasTreoFiveWay
&& handleFocusEvent( globals, event, &draw ); && handleFocusEvent( globals, event, &draw );
break; break;
#endif #endif
case keyDownEvent:
case keyUpEvent: case keyUpEvent:
XP_ASSERT( globals->hasTreoKeyboard );
case keyDownEvent:
if ( !globals->menuIsDown ) {
draw = handleKeyEvent( globals, event, &handled ); draw = handleKeyEvent( globals, event, &handled );
}
break; break;
case sclRepeatEvent: case sclRepeatEvent:

View file

@ -295,8 +295,8 @@ struct PalmAppGlobals {
XP_Bool hasHiRes; XP_Bool hasHiRes;
XP_Bool oneDotFiveAvail; XP_Bool oneDotFiveAvail;
XP_Bool useHiRes; XP_Bool useHiRes;
XP_Bool hasFiveWay; XP_Bool hasTreoFiveWay;
XP_Bool hasKeyboard; XP_Bool hasTreoKeyboard;
XP_U16 lastKeyDown; XP_U16 lastKeyDown;