curses app tweaks (smaller scoreboard)

This commit is contained in:
Eric House 2020-01-31 17:55:15 -08:00
parent cdcf63a0bf
commit edec1c01fd
2 changed files with 25 additions and 11 deletions

View file

@ -550,6 +550,7 @@ setupBoard( CursesBoardGlobals* bGlobals )
XP_FALSE, &dims ); XP_FALSE, &dims );
board_applyLayout( board, &dims ); board_applyLayout( board, &dims );
XP_LOGF( "%s(): calling board_draw()", __func__ ); XP_LOGF( "%s(): calling board_draw()", __func__ );
board_invalAll( board );
board_draw( board ); board_draw( board );
} }

View file

@ -131,8 +131,14 @@ static void
formatRemText( XP_S16 nTilesLeft, const XP_Rect* rect, char* buf, char** lines ) formatRemText( XP_S16 nTilesLeft, const XP_Rect* rect, char* buf, char** lines )
{ {
if ( 1 == rect->height ) { if ( 1 == rect->height ) {
const char* fmt;
if ( rect->width < 15 ) {
fmt = "%d";
} else {
fmt = "Rem: %.3d";
}
*lines = buf; *lines = buf;
sprintf( buf, "Rem: %.3d", nTilesLeft ); sprintf( buf, fmt, nTilesLeft );
} else { } else {
sprintf( buf, "Rem:" ); sprintf( buf, "Rem:" );
*lines++ = buf; *lines++ = buf;
@ -148,6 +154,9 @@ curses_draw_measureRemText( DrawCtx* XP_UNUSED(dctx),
XP_S16 nTilesLeft, XP_S16 nTilesLeft,
XP_U16* width, XP_U16* height ) XP_U16* width, XP_U16* height )
{ {
if ( 0 == nTilesLeft ) {
*width = *height = 0;
} else {
char buf[64]; char buf[64];
char* lines[2] = {0}; char* lines[2] = {0};
formatRemText( nTilesLeft, rect, buf, lines ); formatRemText( nTilesLeft, rect, buf, lines );
@ -158,7 +167,7 @@ curses_draw_measureRemText( DrawCtx* XP_UNUSED(dctx),
*width = XP_MAX( *width, strlen(lines[ii]) ); *width = XP_MAX( *width, strlen(lines[ii]) );
} }
*height = ii; *height = ii;
}
return XP_TRUE; return XP_TRUE;
} /* curses_draw_measureRemText */ } /* curses_draw_measureRemText */
@ -222,7 +231,11 @@ formatScoreText( XP_UCHAR* out, const DrawScoreInfo* dsi, const XP_Rect* rect,
out += 4; out += 4;
} }
if ( 1 == rect->height ) {
sprintf( out, "%c:%.3d", dsi->name[0], dsi->totalScore );
} else {
sprintf( out, "%.3d", dsi->totalScore ); sprintf( out, "%.3d", dsi->totalScore );
}
*lines++ = out; *lines++ = out;
out += 1 + strlen(out); out += 1 + strlen(out);