improve drawCell()

This commit is contained in:
Eric House 2021-02-03 12:53:03 -08:00
parent 66a422e2a2
commit ec9570ab81
4 changed files with 132 additions and 26 deletions

View file

@ -366,6 +366,15 @@ p_replaceStringIfDifferent( MPFORMAL XP_UCHAR** curLoc, const XP_UCHAR* newStr
*curLoc = curStr; *curLoc = curStr;
} /* replaceStringIfDifferent */ } /* replaceStringIfDifferent */
void
insetRect( XP_Rect* rect, XP_S16 byWidth, XP_S16 byHeight )
{
rect->width -= byWidth * 2;
rect->left += byWidth;
rect->height -= byHeight * 2;
rect->top += byHeight;
}
XP_U32 XP_U32
augmentHash( XP_U32 hash, const XP_U8* ptr, XP_U16 len ) augmentHash( XP_U32 hash, const XP_U8* ptr, XP_U16 len )
{ {

View file

@ -81,6 +81,8 @@ XP_UCHAR* p_copyString( MPFORMAL const XP_UCHAR* instr
# define copyString( p, in ) p_copyString( in ) # define copyString( p, in ) p_copyString( in )
#endif #endif
void insetRect( XP_Rect* rect, XP_S16 byWidth, XP_S16 byHeight );
XP_U32 augmentHash( XP_U32 hash, const XP_U8* ptr, XP_U16 len ); XP_U32 augmentHash( XP_U32 hash, const XP_U8* ptr, XP_U16 len );
XP_U32 finishHash( XP_U32 hash ); XP_U32 finishHash( XP_U32 hash );

View file

@ -23,6 +23,7 @@ DEFINES += -DXWFEATURE_KNOWNPLAYERS
DEFINES += -DXWFEATURE_DICTSANITY DEFINES += -DXWFEATURE_DICTSANITY
DEFINES += -DPOINTER_SUPPORT DEFINES += -DPOINTER_SUPPORT
DEFINES += -DPLATFORM_WASM DEFINES += -DPLATFORM_WASM
DEFINES += -DXWFEATURE_CROSSHAIRS
OUTPUTS = main.html main.js main.js.mem main.data main.html.mem OUTPUTS = main.html main.js main.js.mem main.data main.html.mem

View file

@ -3,11 +3,9 @@
#include <SDL2/SDL_image.h> #include <SDL2/SDL_image.h>
#include "comtypes.h" #include "comtypes.h"
#include "strutils.h"
#include "wasmdraw.h" #include "wasmdraw.h"
#define COLOR_BACK 255, 255, 255
#define COLOR_BLACK 0, 0, 0
typedef struct _WasmDrawCtx { typedef struct _WasmDrawCtx {
DrawCtxVTable* vtable; DrawCtxVTable* vtable;
SDL_Renderer* renderer; SDL_Renderer* renderer;
@ -23,13 +21,21 @@ typedef struct _WasmDrawCtx {
SDL_Surface* origin; SDL_Surface* origin;
int trayOwner; int trayOwner;
XP_Bool inTrade;
} WasmDrawCtx; } WasmDrawCtx;
static int sBonusColors[4][3] = { static SDL_Color sBonusColors[4] = {
{0x00, 0xFF, 0x80}, {0xAF, 0xAF, 0x00, 0xFF},
{0x00, 0x80, 0xFF}, {0x00, 0xAF, 0xAF,0xFF},
{0x80, 0x00, 0xFF}, {0xAF, 0x00, 0xAF,0xFF},
{0xFF, 0x80, 0x00}, {0xAF, 0xAF, 0xAF,0xFF},
};
static XP_UCHAR* sBonusSummaries[] = {
"2L",
"2W",
"3L",
"3W",
}; };
static SDL_Color sPlayerColors[4] = { static SDL_Color sPlayerColors[4] = {
@ -39,6 +45,27 @@ static SDL_Color sPlayerColors[4] = {
{0xFF, 0x80, 0x00, 0xFF}, {0xFF, 0x80, 0x00, 0xFF},
}; };
enum { BLACK,
WHITE,
COLOR_FOCUS,
COLOR_NOTILE,
COLOR_TILE_BACK,
COLOR_BONUSHINT,
COLOR_BACK,
N_COLORS,
};
static SDL_Color sOtherColors[N_COLORS] = {
{0x00, 0x00, 0x00, 0xFF}, /* BLACK */
{0xFF, 0xFF, 0xFF, 0xFF}, /* WHITE */
{0x70, 0x70, 0xFF, 0xFF}, /* COLOR_FOCUS, */
{0xFF, 0xFF, 0xFF, 0xFF}, /* COLOR_NOTILE, */
{0xFF, 0xFF, 0x99, 0xFF}, /* COLOR_TILE_BACK, */
{0x7F, 0x7F, 0x7F, 0xFF},/* COLOR_BONUSHINT, */
{0xFF, 0xFF, 0xFF, 0xFF}, /* COLOR_BACK, */
};
static void static void
rectXPToSDL( SDL_Rect* sdlr, const XP_Rect* rect ) rectXPToSDL( SDL_Rect* sdlr, const XP_Rect* rect )
{ {
@ -53,7 +80,8 @@ clearRect( WasmDrawCtx* wdctx, const XP_Rect* rect )
{ {
Uint8 red, green, blue, alpha; Uint8 red, green, blue, alpha;
SDL_GetRenderDrawColor( wdctx->renderer, &red, &green, &blue, &alpha ); SDL_GetRenderDrawColor( wdctx->renderer, &red, &green, &blue, &alpha );
SDL_SetRenderDrawColor( wdctx->renderer, COLOR_BACK, 255 ); const SDL_Color* back = &sOtherColors[COLOR_BACK];
SDL_SetRenderDrawColor( wdctx->renderer, back->r, back->g, back->b, back->a );
SDL_Rect sdlr; SDL_Rect sdlr;
rectXPToSDL( &sdlr, rect ); rectXPToSDL( &sdlr, rect );
@ -71,15 +99,15 @@ setPlayerColor( WasmDrawCtx* wdctx, int owner )
} }
static void static void
fillRect( WasmDrawCtx* wdctx, const XP_Rect* rect, int colorParts[] ) fillRect( WasmDrawCtx* wdctx, const XP_Rect* rect, const SDL_Color* colorParts )
{ {
SDL_Rect sdlr; SDL_Rect sdlr;
rectXPToSDL( &sdlr, rect ); rectXPToSDL( &sdlr, rect );
Uint8 red, green, blue, alpha; Uint8 red, green, blue, alpha;
SDL_GetRenderDrawColor( wdctx->renderer, &red, &green, &blue, &alpha ); SDL_GetRenderDrawColor( wdctx->renderer, &red, &green, &blue, &alpha );
SDL_SetRenderDrawColor( wdctx->renderer, colorParts[0], colorParts[1], SDL_SetRenderDrawColor( wdctx->renderer, colorParts->r, colorParts->g,
colorParts[2], 255 ); colorParts->b, colorParts->a );
SDL_RenderFillRect( wdctx->renderer, &sdlr ); SDL_RenderFillRect( wdctx->renderer, &sdlr );
SDL_SetRenderDrawColor( wdctx->renderer, red, green, blue, alpha ); SDL_SetRenderDrawColor( wdctx->renderer, red, green, blue, alpha );
} }
@ -89,7 +117,9 @@ frameRect( WasmDrawCtx* wdctx, const XP_Rect* rect )
{ {
SDL_Rect sdlr; SDL_Rect sdlr;
rectXPToSDL( &sdlr, rect ); rectXPToSDL( &sdlr, rect );
SDL_SetRenderDrawColor( wdctx->renderer, COLOR_BLACK, 255 ); const SDL_Color* black = &sOtherColors[BLACK];
SDL_SetRenderDrawColor( wdctx->renderer, black->r, black->g,
black->b, black->a );
SDL_RenderDrawRect( wdctx->renderer, &sdlr ); SDL_RenderDrawRect( wdctx->renderer, &sdlr );
} }
@ -318,6 +348,31 @@ wasm_draw_drawTimer( DrawCtx* dctx, XWEnv xwe, const XP_Rect* rect,
XP_U16 player, XP_S16 secondsLeft, XP_U16 player, XP_S16 secondsLeft,
XP_Bool turnDone ){ LOG_FUNC(); } XP_Bool turnDone ){ LOG_FUNC(); }
static void
markBlank( WasmDrawCtx* wdctx, const XP_Rect* rect, const SDL_Color* backColor )
{
}
static void
drawCrosshairs( WasmDrawCtx* wdctx, const XP_Rect* rect, CellFlags flags )
{
const SDL_Color* color = &sOtherColors[COLOR_FOCUS];
if ( 0 != (flags & CELL_CROSSHOR) ) {
XP_Rect hairRect = *rect;
XP_LOGFF( "hairRect before: l: %d, t: %d, w: %d, h: %d",
hairRect.left, hairRect.top, hairRect.width, hairRect.height );
insetRect( &hairRect, 0, hairRect.height / 3 );
XP_LOGFF( "hairRect after: l: %d, t: %d, w: %d, h: %d",
hairRect.left, hairRect.top, hairRect.width, hairRect.height );
fillRect( wdctx, &hairRect, color );
}
if ( 0 != (flags & CELL_CROSSVERT) ) {
XP_Rect hairRect = *rect;
insetRect( &hairRect, hairRect.width / 3, 0 );
fillRect( wdctx, &hairRect, color );
}
}
static XP_Bool static XP_Bool
wasm_draw_drawCell( DrawCtx* dctx, XWEnv xwe, const XP_Rect* rect, wasm_draw_drawCell( DrawCtx* dctx, XWEnv xwe, const XP_Rect* rect,
/* at least one of these two will be /* at least one of these two will be
@ -330,23 +385,62 @@ wasm_draw_drawCell( DrawCtx* dctx, XWEnv xwe, const XP_Rect* rect,
CellFlags flags ) CellFlags flags )
{ {
WasmDrawCtx* wdctx = (WasmDrawCtx*)dctx; WasmDrawCtx* wdctx = (WasmDrawCtx*)dctx;
clearRect( wdctx, rect ); const SDL_Color* backColor = NULL;
XP_Bool empty = 0 != (flags & (CELL_DRAGSRC|CELL_ISEMPTY));
XP_Bool pending = 0 != (flags & CELL_PENDING);
XP_Bool recent = 0 != (flags & CELL_RECENT);
XP_UCHAR* bonusStr = NULL;
if ( (flags & (CELL_DRAGSRC|CELL_ISEMPTY)) != 0 ) { /* if ( wdctx->inTrade ) { */
if ( BONUS_NONE == bonus ) { /* fillRectOther( rect, CommonPrefs.COLOR_BACKGRND ); */
clearRect( wdctx, rect ); /* } */
if ( owner < 0 ) {
owner = 0;
}
const SDL_Color* foreColor = &sPlayerColors[owner];
if ( 0 != (flags & CELL_ISCURSOR) ) {
backColor = &sOtherColors[COLOR_FOCUS];
} else if ( empty ) {
if ( 0 == bonus ) {
backColor = &sOtherColors[COLOR_NOTILE];
} else { } else {
fillRect( wdctx, rect, sBonusColors[bonus-1] ); backColor = &sBonusColors[bonus-1];
bonusStr = sBonusSummaries[bonus-1];
} }
if ( 0 != (flags & CELL_ISSTAR) ) { } else if ( pending || recent ) {
imgInRect( wdctx, wdctx->origin, rect ); foreColor = &sOtherColors[WHITE];
} backColor = &sOtherColors[BLACK];
} else if ( !!text ) { } else {
textInRect( wdctx, text, rect, NULL ); backColor = &sOtherColors[COLOR_TILE_BACK];
} }
fillRect( wdctx, rect, backColor );
if ( empty ) {
if ( (CELL_ISSTAR & flags) != 0 ) {
imgInRect( wdctx, wdctx->origin, rect );
} else if ( NULL != bonusStr ) {
const SDL_Color* color = &sOtherColors[COLOR_BONUSHINT];
/* m_fillPaint.setColor( adjustColor(color) ); */
/* Rect brect = new Rect( rect ); */
/* brect.inset( 0, brect.height()/10 ); */
/* drawCentered( bonusStr, brect, m_fontDims ); */
textInRect( wdctx, bonusStr, rect, color );
}
} else {
textInRect( wdctx, text, rect, foreColor );
}
if ( (CELL_ISBLANK & flags) != 0 ) {
markBlank( wdctx, rect, backColor );
}
// frame the cell
frameRect( wdctx, rect ); frameRect( wdctx, rect );
drawCrosshairs( wdctx, rect, flags );
return XP_TRUE; return XP_TRUE;
} }