mirror of
git://xwords.git.sourceforge.net/gitroot/xwords/xwords
synced 2025-01-22 07:28:16 +01:00
improve drawCell()
This commit is contained in:
parent
66a422e2a2
commit
ec9570ab81
4 changed files with 132 additions and 26 deletions
|
@ -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 )
|
||||||
{
|
{
|
||||||
|
|
|
@ -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 );
|
||||||
|
|
||||||
|
|
|
@ -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
|
||||||
|
|
||||||
|
|
|
@ -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;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue