mirror of
git://xwords.git.sourceforge.net/gitroot/xwords/xwords
synced 2025-01-13 08:01:33 +01:00
include name of player whose turn it is in scoreboard entry, reducing
length until it fits.
This commit is contained in:
parent
e7f476c13e
commit
e539b49948
1 changed files with 54 additions and 32 deletions
|
@ -47,7 +47,7 @@
|
||||||
#define CE_MINI_H_PADDING 8
|
#define CE_MINI_H_PADDING 8
|
||||||
#define CE_MINIW_PADDING 0
|
#define CE_MINIW_PADDING 0
|
||||||
#define CE_TIMER_PADDING -2
|
#define CE_TIMER_PADDING -2
|
||||||
#define IS_TURN_VPAD 2
|
#define SCORE_HPAD 2
|
||||||
|
|
||||||
//#define DRAW_FOCUS_FRAME 1
|
//#define DRAW_FOCUS_FRAME 1
|
||||||
#ifdef DRAW_FOCUS_FRAME
|
#ifdef DRAW_FOCUS_FRAME
|
||||||
|
@ -102,6 +102,8 @@ struct CEDrawCtx {
|
||||||
const DictionaryCtxt* dict;
|
const DictionaryCtxt* dict;
|
||||||
UINT codePage;
|
UINT codePage;
|
||||||
|
|
||||||
|
XP_UCHAR scoreCache[MAX_NUM_PLAYERS][32];
|
||||||
|
|
||||||
COLORREF prevBkColor;
|
COLORREF prevBkColor;
|
||||||
|
|
||||||
HBRUSH brushes[CE_NUM_COLORS];
|
HBRUSH brushes[CE_NUM_COLORS];
|
||||||
|
@ -221,7 +223,7 @@ ceDrawTextClipped( HDC hdc, wchar_t* buf, XP_S16 len, XP_Bool clip,
|
||||||
} /* ceDrawTextClipped */
|
} /* ceDrawTextClipped */
|
||||||
|
|
||||||
static void
|
static void
|
||||||
ceDrawLinesClipped( HDC hdc, const FontCacheEntry* fce, XP_UCHAR* buf,
|
ceDrawLinesClipped( HDC hdc, const FontCacheEntry* fce, const XP_UCHAR* buf,
|
||||||
UINT codePage, XP_Bool clip, const RECT* bounds )
|
UINT codePage, XP_Bool clip, const RECT* bounds )
|
||||||
{
|
{
|
||||||
XP_U16 top = bounds->top;
|
XP_U16 top = bounds->top;
|
||||||
|
@ -1473,23 +1475,30 @@ DRAW_FUNC_NAME(drawRemText)( DrawCtx* p_dctx, const XP_Rect* rInner,
|
||||||
} /* ce_draw_drawRemText */
|
} /* ce_draw_drawRemText */
|
||||||
|
|
||||||
static void
|
static void
|
||||||
ceFormatScoreText( CEDrawCtx* dctx, const DrawScoreInfo* dsi,
|
ceFormatScoreText( CEDrawCtx* dctx, const DrawScoreInfo* dsi, XP_U16 nameLen )
|
||||||
XP_UCHAR* buf, XP_U16 buflen )
|
|
||||||
{
|
{
|
||||||
XP_UCHAR bullet[] = {'•', '\0'};
|
|
||||||
XP_UCHAR optPart[16];
|
XP_UCHAR optPart[16];
|
||||||
|
XP_UCHAR name[nameLen+1+1];
|
||||||
|
|
||||||
/* For a horizontal scoreboard, we want *300:6*
|
/* For a horizontal scoreboard, we want [name ]300:6
|
||||||
* For a vertical, it's
|
* For a vertical, it's
|
||||||
*
|
*
|
||||||
|
* [name]
|
||||||
* 300
|
* 300
|
||||||
* 6
|
* 6
|
||||||
*
|
|
||||||
* with IS_TURN_VPAD-height rects above and below
|
|
||||||
*/
|
*/
|
||||||
|
|
||||||
if ( !dsi->isTurn || dctx->scoreIsVertical ) {
|
while ( nameLen >= 1 ) {
|
||||||
bullet[0] = '\0';
|
snprintf( name, nameLen+1, "%s", dsi->name );
|
||||||
|
if ( name[nameLen-1] == ' ' ) { /* don't end with space */
|
||||||
|
--nameLen;
|
||||||
|
} else {
|
||||||
|
XP_STRCAT( name, dctx->scoreIsVertical? XP_CR : " " );
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
if ( nameLen < 1 ) {
|
||||||
|
name[0] = '\0';
|
||||||
}
|
}
|
||||||
|
|
||||||
if ( dsi->nTilesLeft >= 0 ) {
|
if ( dsi->nTilesLeft >= 0 ) {
|
||||||
|
@ -1499,8 +1508,9 @@ ceFormatScoreText( CEDrawCtx* dctx, const DrawScoreInfo* dsi,
|
||||||
optPart[0] = '\0';
|
optPart[0] = '\0';
|
||||||
}
|
}
|
||||||
|
|
||||||
snprintf( buf, buflen, "%s%d%s%s",
|
snprintf( dctx->scoreCache[dsi->playerNum],
|
||||||
bullet, dsi->totalScore, optPart, bullet );
|
VSIZE(dctx->scoreCache[dsi->playerNum]),
|
||||||
|
"%s%d%s", name, dsi->totalScore, optPart );
|
||||||
} /* ceFormatScoreText */
|
} /* ceFormatScoreText */
|
||||||
|
|
||||||
DLSTATIC void
|
DLSTATIC void
|
||||||
|
@ -1511,10 +1521,15 @@ DRAW_FUNC_NAME(measureScoreText)( 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;
|
||||||
HDC hdc = globals->hdc;
|
HDC hdc = globals->hdc;
|
||||||
XP_UCHAR buf[32];
|
|
||||||
HFONT oldFont;
|
HFONT oldFont;
|
||||||
const FontCacheEntry* fce;
|
const FontCacheEntry* fce;
|
||||||
XP_U16 fontHt, cellHt;
|
XP_U16 fontHt, cellHt;
|
||||||
|
XP_U16 nameLen;
|
||||||
|
XP_U16 targetWidth = xprect->width;
|
||||||
|
|
||||||
|
if ( !dctx->scoreIsVertical ) {
|
||||||
|
targetWidth -= (SCORE_HPAD * 2);
|
||||||
|
}
|
||||||
|
|
||||||
cellHt = globals->cellHt;
|
cellHt = globals->cellHt;
|
||||||
if ( !dctx->scoreIsVertical ) {
|
if ( !dctx->scoreIsVertical ) {
|
||||||
|
@ -1529,19 +1544,33 @@ DRAW_FUNC_NAME(measureScoreText)( DrawCtx* p_dctx, const XP_Rect* xprect,
|
||||||
fontHt -= 2; /* use smaller font for non-selected */
|
fontHt -= 2; /* use smaller font for non-selected */
|
||||||
}
|
}
|
||||||
|
|
||||||
ceFormatScoreText( dctx, dsi, buf, sizeof(buf) );
|
|
||||||
|
|
||||||
fce = ceGetSizedFont( dctx, fontHt, 0,
|
fce = ceGetSizedFont( dctx, fontHt, 0,
|
||||||
dsi->selected ? RFONTS_SCORE_BOLD:RFONTS_SCORE );
|
dsi->selected ? RFONTS_SCORE_BOLD:RFONTS_SCORE );
|
||||||
|
nameLen = dsi->isTurn? XP_STRLEN(dsi->name) : 0;
|
||||||
oldFont = SelectObject( hdc, fce->setFont );
|
oldFont = SelectObject( hdc, fce->setFont );
|
||||||
|
|
||||||
ceMeasureText( dctx, hdc, fce, buf, 0, widthP, heightP );
|
for ( ; ; ) {
|
||||||
|
XP_U16 width, height;
|
||||||
|
ceFormatScoreText( dctx, dsi, nameLen );
|
||||||
|
|
||||||
|
ceMeasureText( dctx, hdc, fce, dctx->scoreCache[dsi->playerNum], 0,
|
||||||
|
&width, &height );
|
||||||
|
|
||||||
|
if ( width <= targetWidth && height <= xprect->height ) {
|
||||||
|
if ( !dctx->scoreIsVertical ) {
|
||||||
|
width += (SCORE_HPAD * 2);
|
||||||
|
}
|
||||||
|
*widthP = width;
|
||||||
|
*heightP = height;
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
XP_ASSERT( dsi->isTurn ); /* fired */
|
||||||
|
if ( --nameLen == 0 ) {
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
SelectObject( hdc, oldFont );
|
SelectObject( hdc, oldFont );
|
||||||
|
|
||||||
if ( dsi->isTurn && dctx->scoreIsVertical ) {
|
|
||||||
*heightP += IS_TURN_VPAD * 2;
|
|
||||||
}
|
|
||||||
} /* ce_draw_measureScoreText */
|
} /* ce_draw_measureScoreText */
|
||||||
|
|
||||||
DLSTATIC void
|
DLSTATIC void
|
||||||
|
@ -1554,7 +1583,6 @@ DRAW_FUNC_NAME(score_drawPlayer)( DrawCtx* p_dctx,
|
||||||
CEAppGlobals* globals = dctx->globals;
|
CEAppGlobals* globals = dctx->globals;
|
||||||
HDC hdc = globals->hdc;
|
HDC hdc = globals->hdc;
|
||||||
RECT rt;
|
RECT rt;
|
||||||
XP_UCHAR buf[20];
|
|
||||||
HFONT oldFont;
|
HFONT oldFont;
|
||||||
XP_Bool isFocussed = (dsi->flags & CELL_ISCURSOR) != 0;
|
XP_Bool isFocussed = (dsi->flags & CELL_ISCURSOR) != 0;
|
||||||
XP_U16 bkIndex = isFocussed ? CE_FOCUS_COLOR : CE_BKG_COLOR;
|
XP_U16 bkIndex = isFocussed ? CE_FOCUS_COLOR : CE_BKG_COLOR;
|
||||||
|
@ -1574,20 +1602,14 @@ DRAW_FUNC_NAME(score_drawPlayer)( DrawCtx* p_dctx,
|
||||||
FillRect( hdc, &rt, dctx->brushes[CE_FOCUS_COLOR] );
|
FillRect( hdc, &rt, dctx->brushes[CE_FOCUS_COLOR] );
|
||||||
}
|
}
|
||||||
|
|
||||||
ceFormatScoreText( dctx, dsi, buf, sizeof(buf) );
|
|
||||||
|
|
||||||
XPRtoRECT( &rt, rInner );
|
XPRtoRECT( &rt, rInner );
|
||||||
|
|
||||||
if ( dsi->isTurn && dctx->scoreIsVertical ) {
|
if ( !dctx->scoreIsVertical ) {
|
||||||
Rectangle( hdc, rt.left, rt.top-IS_TURN_VPAD, rt.right, rt.top );
|
rt.left += SCORE_HPAD;
|
||||||
Rectangle( hdc, rt.left, rt.bottom, rt.right,
|
rt.right -= SCORE_HPAD;
|
||||||
rt.bottom + IS_TURN_VPAD );
|
|
||||||
|
|
||||||
rt.top += IS_TURN_VPAD;
|
|
||||||
rt.bottom -= IS_TURN_VPAD;
|
|
||||||
}
|
}
|
||||||
|
ceDrawLinesClipped( hdc, fce, dctx->scoreCache[dsi->playerNum],
|
||||||
ceDrawLinesClipped( hdc, fce, buf, CP_ACP, XP_TRUE, &rt );
|
CP_ACP, XP_TRUE, &rt );
|
||||||
|
|
||||||
SelectObject( hdc, oldFont );
|
SelectObject( hdc, oldFont );
|
||||||
} /* ce_draw_score_drawPlayer */
|
} /* ce_draw_score_drawPlayer */
|
||||||
|
|
Loading…
Reference in a new issue