mirror of
git://xwords.git.sourceforge.net/gitroot/xwords/xwords
synced 2025-01-18 22:26:30 +01:00
set text color before drawing star bitmap to make color consistent;
add utility function for setting colors to reduce code size.
This commit is contained in:
parent
07e3b26e60
commit
6693565ad5
1 changed files with 29 additions and 18 deletions
|
@ -787,6 +787,18 @@ ceDrawHintBorders( CEDrawCtx* dctx, const XP_Rect* xprect, HintAtts hintAtts )
|
||||||
}
|
}
|
||||||
} /* ceDrawHintBorders */
|
} /* ceDrawHintBorders */
|
||||||
|
|
||||||
|
static void
|
||||||
|
ceSetTextColor( HDC hdc, const CEDrawCtx* dctx, XP_U16 index )
|
||||||
|
{
|
||||||
|
SetTextColor( hdc, dctx->globals->appPrefs.colors[index] );
|
||||||
|
}
|
||||||
|
|
||||||
|
static void
|
||||||
|
ceSetBkColor( HDC hdc, const CEDrawCtx* dctx, XP_U16 index )
|
||||||
|
{
|
||||||
|
SetBkColor( hdc, dctx->globals->appPrefs.colors[index] );
|
||||||
|
}
|
||||||
|
|
||||||
DLSTATIC XP_Bool
|
DLSTATIC XP_Bool
|
||||||
DRAW_FUNC_NAME(drawCell)( DrawCtx* p_dctx, const XP_Rect* xprect,
|
DRAW_FUNC_NAME(drawCell)( DrawCtx* p_dctx, const XP_Rect* xprect,
|
||||||
const XP_UCHAR* letters,
|
const XP_UCHAR* letters,
|
||||||
|
@ -866,7 +878,7 @@ DRAW_FUNC_NAME(drawCell)( DrawCtx* p_dctx, const XP_Rect* xprect,
|
||||||
FillRect( hdc, &tmpRT, dctx->brushes[bkIndex] );
|
FillRect( hdc, &tmpRT, dctx->brushes[bkIndex] );
|
||||||
}
|
}
|
||||||
|
|
||||||
SetBkColor( hdc, dctx->globals->appPrefs.colors[bkIndex] );
|
ceSetBkColor( hdc, dctx, bkIndex );
|
||||||
|
|
||||||
if ( !isDragSrc && !!letters && (letters[0] != '\0') ) {
|
if ( !isDragSrc && !!letters && (letters[0] != '\0') ) {
|
||||||
wchar_t widebuf[4];
|
wchar_t widebuf[4];
|
||||||
|
@ -874,7 +886,7 @@ DRAW_FUNC_NAME(drawCell)( DrawCtx* p_dctx, const XP_Rect* xprect,
|
||||||
MultiByteToWideChar( CP_ACP, MB_PRECOMPOSED, letters, -1,
|
MultiByteToWideChar( CP_ACP, MB_PRECOMPOSED, letters, -1,
|
||||||
widebuf, VSIZE(widebuf) );
|
widebuf, VSIZE(widebuf) );
|
||||||
|
|
||||||
SetTextColor( hdc, dctx->globals->appPrefs.colors[foreColorIndx] );
|
ceSetTextColor( hdc, dctx, foreColorIndx );
|
||||||
#ifndef _WIN32_WCE
|
#ifndef _WIN32_WCE
|
||||||
MultiByteToWideChar( CP_ACP, MB_PRECOMPOSED, letters, -1,
|
MultiByteToWideChar( CP_ACP, MB_PRECOMPOSED, letters, -1,
|
||||||
widebuf, VSIZE(widebuf) );
|
widebuf, VSIZE(widebuf) );
|
||||||
|
@ -882,6 +894,7 @@ DRAW_FUNC_NAME(drawCell)( DrawCtx* p_dctx, const XP_Rect* xprect,
|
||||||
ceDrawTextClipped( hdc, widebuf, -1, XP_FALSE, fce, xprect->left+1,
|
ceDrawTextClipped( hdc, widebuf, -1, XP_FALSE, fce, xprect->left+1,
|
||||||
xprect->top+2, xprect->width, DT_CENTER );
|
xprect->top+2, xprect->width, DT_CENTER );
|
||||||
} else if ( (flags&CELL_ISSTAR) != 0 ) {
|
} else if ( (flags&CELL_ISSTAR) != 0 ) {
|
||||||
|
ceSetTextColor( hdc, dctx, CE_BLACK_COLOR );
|
||||||
ceDrawBitmapInRect( hdc, &textRect, dctx->origin );
|
ceDrawBitmapInRect( hdc, &textRect, dctx->origin );
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -962,7 +975,7 @@ drawDrawTileGuts( DrawCtx* p_dctx, const XP_Rect* xprect,
|
||||||
if ( !isEmpty || focLevel == SINGLE_FOCUS ) { /* don't draw anything unless SINGLE_FOCUS */
|
if ( !isEmpty || focLevel == SINGLE_FOCUS ) { /* don't draw anything unless SINGLE_FOCUS */
|
||||||
XP_U16 backIndex = focLevel == NO_FOCUS? CE_TILEBACK_COLOR : CE_FOCUS_COLOR;
|
XP_U16 backIndex = focLevel == NO_FOCUS? CE_TILEBACK_COLOR : CE_FOCUS_COLOR;
|
||||||
|
|
||||||
SetBkColor( hdc, dctx->globals->appPrefs.colors[backIndex] );
|
ceSetBkColor( hdc, dctx, backIndex );
|
||||||
|
|
||||||
InsetRect( &rt, 1, 1 );
|
InsetRect( &rt, 1, 1 );
|
||||||
Rectangle( hdc, rt.left, rt.top, rt.right, rt.bottom); /* draw frame */
|
Rectangle( hdc, rt.left, rt.top, rt.right, rt.bottom); /* draw frame */
|
||||||
|
@ -970,7 +983,7 @@ drawDrawTileGuts( DrawCtx* p_dctx, const XP_Rect* xprect,
|
||||||
|
|
||||||
if ( !isEmpty ) {
|
if ( !isEmpty ) {
|
||||||
index = getPlayerColor(dctx->trayOwner);
|
index = getPlayerColor(dctx->trayOwner);
|
||||||
SetTextColor( hdc, dctx->globals->appPrefs.colors[index] );
|
ceSetTextColor( hdc, dctx, index );
|
||||||
|
|
||||||
/* For some reason Rectangle isn't using the background brush to
|
/* For some reason Rectangle isn't using the background brush to
|
||||||
fill, so FillRect has to get called after Rectangle. Need to
|
fill, so FillRect has to get called after Rectangle. Need to
|
||||||
|
@ -1170,8 +1183,8 @@ DRAW_FUNC_NAME(drawBoardArrow)( DrawCtx* p_dctx, const XP_Rect* xprect,
|
||||||
bkIndex = cursorBonus - BONUS_DOUBLE_LETTER + CE_BONUS0_COLOR;
|
bkIndex = cursorBonus - BONUS_DOUBLE_LETTER + CE_BONUS0_COLOR;
|
||||||
}
|
}
|
||||||
FillRect( hdc, &rt, dctx->brushes[bkIndex] );
|
FillRect( hdc, &rt, dctx->brushes[bkIndex] );
|
||||||
SetBkColor( hdc, dctx->globals->appPrefs.colors[bkIndex] );
|
ceSetBkColor( hdc, dctx, bkIndex );
|
||||||
SetTextColor( hdc, dctx->globals->appPrefs.colors[CE_BLACK_COLOR] );
|
ceSetTextColor( hdc, dctx, CE_BLACK_COLOR );
|
||||||
|
|
||||||
ceDrawBitmapInRect( hdc, &rt, cursor );
|
ceDrawBitmapInRect( hdc, &rt, cursor );
|
||||||
|
|
||||||
|
@ -1186,7 +1199,7 @@ DRAW_FUNC_NAME(scoreBegin)( DrawCtx* p_dctx, const XP_Rect* xprect,
|
||||||
CEDrawCtx* dctx = (CEDrawCtx*)p_dctx;
|
CEDrawCtx* dctx = (CEDrawCtx*)p_dctx;
|
||||||
CEAppGlobals* globals = dctx->globals;
|
CEAppGlobals* globals = dctx->globals;
|
||||||
XP_ASSERT( !!globals->hdc );
|
XP_ASSERT( !!globals->hdc );
|
||||||
SetBkColor( globals->hdc, dctx->globals->appPrefs.colors[CE_BKG_COLOR] );
|
ceSetBkColor( globals->hdc, dctx, CE_BKG_COLOR );
|
||||||
|
|
||||||
dctx->scoreIsVertical = xprect->height > xprect->width;
|
dctx->scoreIsVertical = xprect->height > xprect->width;
|
||||||
|
|
||||||
|
@ -1259,7 +1272,7 @@ DRAW_FUNC_NAME(drawRemText)( DrawCtx* p_dctx, const XP_Rect* rInner,
|
||||||
|
|
||||||
XPRtoRECT( &rt, rInner );
|
XPRtoRECT( &rt, rInner );
|
||||||
if ( focussed ) {
|
if ( focussed ) {
|
||||||
SetBkColor( hdc, dctx->globals->appPrefs.colors[CE_FOCUS_COLOR] );
|
ceSetBkColor( hdc, dctx, CE_FOCUS_COLOR );
|
||||||
FillRect( hdc, &rt, dctx->brushes[CE_FOCUS_COLOR] );
|
FillRect( hdc, &rt, dctx->brushes[CE_FOCUS_COLOR] );
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1365,9 +1378,8 @@ DRAW_FUNC_NAME(score_drawPlayer)( DrawCtx* p_dctx,
|
||||||
|
|
||||||
oldFont = SelectObject( hdc, fce->setFont );
|
oldFont = SelectObject( hdc, fce->setFont );
|
||||||
|
|
||||||
SetTextColor( hdc, dctx->globals->
|
ceSetTextColor( hdc, dctx, getPlayerColor(dsi->playerNum) );
|
||||||
appPrefs.colors[getPlayerColor(dsi->playerNum)] );
|
ceSetBkColor( hdc, dctx, bkIndex );
|
||||||
SetBkColor( hdc, dctx->globals->appPrefs.colors[bkIndex] );
|
|
||||||
|
|
||||||
XPRtoRECT( &rt, rOuter );
|
XPRtoRECT( &rt, rOuter );
|
||||||
ceClipToRect( hdc, &rt );
|
ceClipToRect( hdc, &rt );
|
||||||
|
@ -1415,9 +1427,8 @@ DRAW_FUNC_NAME(score_pendingScore)( DrawCtx* p_dctx, const XP_Rect* xprect,
|
||||||
|
|
||||||
oldFont = SelectObject( hdc, fce->setFont );
|
oldFont = SelectObject( hdc, fce->setFont );
|
||||||
|
|
||||||
SetTextColor( hdc,
|
ceSetTextColor( hdc, dctx, getPlayerColor(playerNum) );
|
||||||
dctx->globals->appPrefs.colors[getPlayerColor(playerNum)] );
|
ceSetBkColor( hdc, dctx, bkIndex );
|
||||||
SetBkColor( hdc, dctx->globals->appPrefs.colors[bkIndex] );
|
|
||||||
|
|
||||||
XPRtoRECT( &rt, xprect );
|
XPRtoRECT( &rt, xprect );
|
||||||
ceClipToRect( hdc, &rt );
|
ceClipToRect( hdc, &rt );
|
||||||
|
@ -1477,8 +1488,8 @@ DRAW_FUNC_NAME(drawTimer)( DrawCtx* p_dctx, const XP_Rect* rInner,
|
||||||
|
|
||||||
ceClipToRect( hdc, &rt );
|
ceClipToRect( hdc, &rt );
|
||||||
|
|
||||||
SetTextColor( hdc, dctx->globals->appPrefs.colors[getPlayerColor(player)] );
|
ceSetTextColor( hdc, dctx, getPlayerColor(player) );
|
||||||
SetBkColor( hdc, dctx->globals->appPrefs.colors[CE_BKG_COLOR] );
|
ceSetBkColor( hdc, dctx, CE_BKG_COLOR );
|
||||||
ceClearToBkground( dctx, rInner );
|
ceClearToBkground( dctx, rInner );
|
||||||
|
|
||||||
oldFont = SelectObject( hdc, fce->setFont );
|
oldFont = SelectObject( hdc, fce->setFont );
|
||||||
|
@ -1556,8 +1567,8 @@ DRAW_FUNC_NAME(drawMiniWindow)( DrawCtx* p_dctx, const XP_UCHAR* text,
|
||||||
|
|
||||||
ceClearToBkground( dctx, rect );
|
ceClearToBkground( dctx, rect );
|
||||||
|
|
||||||
SetBkColor( hdc, dctx->globals->appPrefs.colors[CE_BKG_COLOR] );
|
ceSetBkColor( hdc, dctx, CE_BKG_COLOR );
|
||||||
SetTextColor( hdc, dctx->globals->appPrefs.colors[CE_BLACK_COLOR] );
|
ceSetTextColor( hdc, dctx, CE_BLACK_COLOR );
|
||||||
|
|
||||||
Rectangle( hdc, rt.left, rt.top, rt.right, rt.bottom );
|
Rectangle( hdc, rt.left, rt.top, rt.right, rt.bottom );
|
||||||
InsetRect( &rt, 1, 1 );
|
InsetRect( &rt, 1, 1 );
|
||||||
|
|
Loading…
Reference in a new issue