Fix drawing highlighted cells on perimeter.

This commit is contained in:
ehouse 2007-01-20 04:30:02 +00:00
parent b4d01f15f2
commit ddeac54995

View file

@ -44,6 +44,11 @@
/* Let's try both for a while */ /* Let's try both for a while */
#define DRAW_FOCUS_FRAME 1 #define DRAW_FOCUS_FRAME 1
#ifdef DRAW_FOCUS_FRAME
# define TREAT_AS_CURSOR(d,f) ((((f) & CELL_ISCURSOR) != 0) && !(d)->topFocus )
#else
# define TREAT_AS_CURSOR(d,f) (((f) & CELL_ISCURSOR) != 0)
#endif
static XP_Bool palm_common_draw_drawCell( DrawCtx* p_dctx, const XP_Rect* rect, static XP_Bool palm_common_draw_drawCell( DrawCtx* p_dctx, const XP_Rect* rect,
const XP_UCHAR* letters, const XP_UCHAR* letters,
@ -323,11 +328,7 @@ palm_clr_draw_drawCell( DrawCtx* p_dctx, const XP_Rect* rect,
PalmDrawCtx* dctx = (PalmDrawCtx*)p_dctx; PalmDrawCtx* dctx = (PalmDrawCtx*)p_dctx;
IndexedColorType color; IndexedColorType color;
XP_U16 index; XP_U16 index;
XP_Bool isCursor = (flags & CELL_ISCURSOR) != 0 XP_Bool isCursor = TREAT_AS_CURSOR( dctx, flags );
#ifdef DRAW_FOCUS_FRAME
&& !dctx->topFocus
#endif
;
XP_Bool isPending = (flags & CELL_HIGHLIGHT) != 0; XP_Bool isPending = (flags & CELL_HIGHLIGHT) != 0;
if ( isCursor ) { if ( isCursor ) {
index = COLOR_CURSOR; index = COLOR_CURSOR;
@ -552,7 +553,7 @@ palm_common_draw_drawCell( DrawCtx* p_dctx, const XP_Rect* rect,
} }
if ( (flags & CELL_HIGHLIGHT) != 0 ) { if ( (flags & CELL_HIGHLIGHT) != 0 ) {
if ( (flags & CELL_ISCURSOR ) == 0 ) { if ( !TREAT_AS_CURSOR( dctx, flags ) ) {
XP_ASSERT( !!bitmap || XP_ASSERT( !!bitmap ||
(!!letters && XP_STRLEN((const char*)letters)>0)); (!!letters && XP_STRLEN((const char*)letters)>0));
WinInvertRectangle( (RectangleType*)&localR, 0 ); WinInvertRectangle( (RectangleType*)&localR, 0 );
@ -659,7 +660,7 @@ palm_draw_drawTile( DrawCtx* p_dctx, const XP_Rect* rect,
draw_clearRect( p_dctx, &localR ); draw_clearRect( p_dctx, &localR );
if ( dctx->topFocus || cursor ) { if ( cursor ) {
(void)WinSetBackColor( dctx->drawingPrefs->drawColors[COLOR_CURSOR] ); (void)WinSetBackColor( dctx->drawingPrefs->drawColors[COLOR_CURSOR] );
if ( dctx->topFocus ) { if ( dctx->topFocus ) {
WinEraseRectangle( (const RectangleType*)&localR, 0 ); WinEraseRectangle( (const RectangleType*)&localR, 0 );
@ -818,7 +819,7 @@ palm_clr_draw_drawBoardArrow( DrawCtx* p_dctx, const XP_Rect* rectP,
PalmDrawCtx* dctx = (PalmDrawCtx*)p_dctx; PalmDrawCtx* dctx = (PalmDrawCtx*)p_dctx;
XP_U16 index; XP_U16 index;
if ( (flags & CELL_ISCURSOR) != 0 ) { if ( TREAT_AS_CURSOR( dctx, flags ) ) {
index = COLOR_CURSOR; index = COLOR_CURSOR;
} else if ( cursorBonus == BONUS_NONE ) { } else if ( cursorBonus == BONUS_NONE ) {
index = COLOR_EMPTY; index = COLOR_EMPTY;