mirror of
git://xwords.git.sourceforge.net/gitroot/xwords/xwords
synced 2025-01-23 07:27:22 +01:00
use bitmaps for arrows and star
This commit is contained in:
parent
5eee1c702e
commit
d36351feb0
1 changed files with 76 additions and 21 deletions
|
@ -39,6 +39,7 @@ extern "C" {
|
||||||
#include <stdio.h>
|
#include <stdio.h>
|
||||||
|
|
||||||
#include "symdraw.h"
|
#include "symdraw.h"
|
||||||
|
#include <xwbitmaps.mbg>
|
||||||
|
|
||||||
#define TRAY_CURSOR_HT 2
|
#define TRAY_CURSOR_HT 2
|
||||||
|
|
||||||
|
@ -77,8 +78,9 @@ typedef struct SymDrawCtxt {
|
||||||
CEikonEnv* iiEikonEnv; /* iEikonEnv is a macro in Symbian headers!!! */
|
CEikonEnv* iiEikonEnv; /* iEikonEnv is a macro in Symbian headers!!! */
|
||||||
CCoeEnv* iCoeEnv;
|
CCoeEnv* iCoeEnv;
|
||||||
|
|
||||||
CFbsBitmap* rightArrow;
|
CFbsBitmap* iRightArrow;
|
||||||
CFbsBitmap* downArrow;
|
CFbsBitmap* iDownArrow;
|
||||||
|
CFbsBitmap* iStar;
|
||||||
|
|
||||||
CONST_60 CFont* iTileFaceFont;
|
CONST_60 CFont* iTileFaceFont;
|
||||||
CONST_60 CFont* iTileValueFont;
|
CONST_60 CFont* iTileValueFont;
|
||||||
|
@ -127,7 +129,7 @@ drawFocusRect( SymDrawCtxt* sctx, XP_Rect* rect, XP_Bool hasfocus )
|
||||||
|
|
||||||
sctx->iGC->SetBrushStyle( CGraphicsContext::ENullBrush );
|
sctx->iGC->SetBrushStyle( CGraphicsContext::ENullBrush );
|
||||||
sctx->iGC->SetPenStyle( CGraphicsContext::EDottedPen );
|
sctx->iGC->SetPenStyle( CGraphicsContext::EDottedPen );
|
||||||
XP_U16 index = hasfocus? COLOR_BLACK : COLOR_WHITE;
|
XP_U16 index = static_cast<XP_U16>(hasfocus? COLOR_BLACK : COLOR_WHITE);
|
||||||
sctx->iGC->SetPenColor( sctx->colors[index] );
|
sctx->iGC->SetPenColor( sctx->colors[index] );
|
||||||
sctx->iGC->DrawRect( lRect );
|
sctx->iGC->DrawRect( lRect );
|
||||||
} // drawFocusRect
|
} // drawFocusRect
|
||||||
|
@ -135,7 +137,7 @@ drawFocusRect( SymDrawCtxt* sctx, XP_Rect* rect, XP_Bool hasfocus )
|
||||||
static void
|
static void
|
||||||
getBonusColor( SymDrawCtxt* sctx, XWBonusType bonus, TRgb* rgb )
|
getBonusColor( SymDrawCtxt* sctx, XWBonusType bonus, TRgb* rgb )
|
||||||
{
|
{
|
||||||
XP_U16 index;
|
TInt index;
|
||||||
if ( bonus == BONUS_NONE ) {
|
if ( bonus == BONUS_NONE ) {
|
||||||
index = COLOR_WHITE;
|
index = COLOR_WHITE;
|
||||||
} else {
|
} else {
|
||||||
|
@ -144,11 +146,35 @@ getBonusColor( SymDrawCtxt* sctx, XWBonusType bonus, TRgb* rgb )
|
||||||
*rgb = sctx->colors[index];
|
*rgb = sctx->colors[index];
|
||||||
} // getBonusColor
|
} // getBonusColor
|
||||||
|
|
||||||
|
static void
|
||||||
|
drawBitmap( SymDrawCtxt* sctx, CFbsBitmap* bmp, const TRect* aRect )
|
||||||
|
{
|
||||||
|
TRect rect( *aRect );
|
||||||
|
TSize bmpSize = bmp->SizeInPixels();
|
||||||
|
if ( bmpSize.iWidth <= rect.Width()
|
||||||
|
&& bmpSize.iHeight <= rect.Height() ) {
|
||||||
|
|
||||||
|
rect.Move( (rect.Width() - bmpSize.iWidth) / 2,
|
||||||
|
(rect.Height() - bmpSize.iHeight) / 2 );
|
||||||
|
rect.SetSize( bmpSize );
|
||||||
|
|
||||||
|
TRect imgRect( TPoint(0,0), bmpSize );
|
||||||
|
sctx->iGC->BitBltMasked( rect.iTl, bmp, imgRect, bmp, ETrue );
|
||||||
|
} else {
|
||||||
|
XP_LOGF( "bitmap too big" );
|
||||||
|
}
|
||||||
|
} /* drawBitmap */
|
||||||
|
|
||||||
static void
|
static void
|
||||||
sym_draw_destroyCtxt( DrawCtx* p_dctx )
|
sym_draw_destroyCtxt( DrawCtx* p_dctx )
|
||||||
{
|
{
|
||||||
SymDrawCtxt* sctx = (SymDrawCtxt*)p_dctx;
|
SymDrawCtxt* sctx = (SymDrawCtxt*)p_dctx;
|
||||||
XP_LOGF( "freeing draw ctxt" );
|
XP_LOGF( "freeing draw ctxt" );
|
||||||
|
|
||||||
|
delete sctx->iRightArrow;
|
||||||
|
delete sctx->iDownArrow;
|
||||||
|
delete sctx->iStar;
|
||||||
|
|
||||||
XP_ASSERT( sctx );
|
XP_ASSERT( sctx );
|
||||||
XP_ASSERT( sctx->vtable );
|
XP_ASSERT( sctx->vtable );
|
||||||
XP_FREE( sctx->mpool, sctx->vtable );
|
XP_FREE( sctx->mpool, sctx->vtable );
|
||||||
|
@ -166,17 +192,19 @@ sym_draw_boardBegin( DrawCtx* p_dctx, XP_Rect* rect,
|
||||||
}
|
}
|
||||||
|
|
||||||
static void
|
static void
|
||||||
sym_draw_boardFinished( DrawCtx* p_dctx )
|
sym_draw_boardFinished( DrawCtx* /*p_dctx*/ )
|
||||||
{
|
{
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#ifdef DEBUG
|
||||||
static XP_Bool
|
static XP_Bool
|
||||||
sym_draw_vertScrollBoard( DrawCtx* p_dctx, XP_Rect* rect,
|
sym_draw_vertScrollBoard( DrawCtx* /*p_dctx*/, XP_Rect* /*rect*/,
|
||||||
XP_S16 dist )
|
XP_S16 /*dist*/ )
|
||||||
{
|
{
|
||||||
XP_ASSERT(0);
|
XP_ASSERT(0);
|
||||||
return XP_FALSE;
|
return XP_FALSE;
|
||||||
}
|
}
|
||||||
|
#endif
|
||||||
|
|
||||||
static XP_Bool
|
static XP_Bool
|
||||||
sym_draw_trayBegin( DrawCtx* p_dctx, XP_Rect* rect,
|
sym_draw_trayBegin( DrawCtx* p_dctx, XP_Rect* rect,
|
||||||
|
@ -220,8 +248,8 @@ sym_draw_measureRemText( DrawCtx* p_dctx, XP_Rect* r,
|
||||||
textToDesc( &tbuf, buf );
|
textToDesc( &tbuf, buf );
|
||||||
|
|
||||||
const CFont* font = sctx->iScoreFont;
|
const CFont* font = sctx->iScoreFont;
|
||||||
*widthP = font->TextWidthInPixels( tbuf );
|
*widthP = (XP_S16)font->TextWidthInPixels( tbuf );
|
||||||
*heightP = font->HeightInPixels();
|
*heightP = (XP_S16)font->HeightInPixels();
|
||||||
} // sym_draw_measureRemText
|
} // sym_draw_measureRemText
|
||||||
|
|
||||||
static void
|
static void
|
||||||
|
@ -309,6 +337,7 @@ sym_draw_score_drawPlayer( DrawCtx* p_dctx,
|
||||||
symClearRect( sctx, &lRect1, COLOR_WHITE );
|
symClearRect( sctx, &lRect1, COLOR_WHITE );
|
||||||
if ( dsi->isTurn ) {
|
if ( dsi->isTurn ) {
|
||||||
TPoint point( lRect1.iTl.iX, lRect.iBr.iY - descent );
|
TPoint point( lRect1.iTl.iX, lRect.iBr.iY - descent );
|
||||||
|
sctx->iGC->SetPenColor( sctx->colors[COLOR_BLACK] ); /* just in case */
|
||||||
sctx->iGC->DrawText( _L("T"), point );
|
sctx->iGC->DrawText( _L("T"), point );
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -337,6 +366,7 @@ sym_draw_score_pendingScore( DrawCtx* p_dctx, XP_Rect* rect,
|
||||||
lRect.Shrink( 1, 1 );
|
lRect.Shrink( 1, 1 );
|
||||||
lRect.SetHeight( lRect.Height() - TRAY_CURSOR_HT );
|
lRect.SetHeight( lRect.Height() - TRAY_CURSOR_HT );
|
||||||
sctx->iGC->SetClippingRect( lRect );
|
sctx->iGC->SetClippingRect( lRect );
|
||||||
|
sctx->iGC->SetPenColor( sctx->colors[COLOR_BLACK] );
|
||||||
|
|
||||||
sctx->iGC->UseFont( sctx->iTileValueFont );
|
sctx->iGC->UseFont( sctx->iTileValueFont );
|
||||||
|
|
||||||
|
@ -431,9 +461,11 @@ sym_draw_drawCell( DrawCtx* p_dctx, XP_Rect* rect,
|
||||||
|
|
||||||
if ( !!bitmap ) {
|
if ( !!bitmap ) {
|
||||||
XP_ASSERT( 0 );
|
XP_ASSERT( 0 );
|
||||||
} else if ( !!text ) {
|
} else if ( !!text && (*text != '\0') ) {
|
||||||
TRect r2(lRect);
|
TRect r2(lRect);
|
||||||
textInCell( sctx, text, &r2, highlight );
|
textInCell( sctx, text, &r2, highlight );
|
||||||
|
} else if ( isStar ) {
|
||||||
|
drawBitmap( sctx, sctx->iStar, &lRect );
|
||||||
}
|
}
|
||||||
|
|
||||||
return XP_TRUE;
|
return XP_TRUE;
|
||||||
|
@ -548,20 +580,19 @@ sym_draw_drawBoardArrow( DrawCtx* p_dctx, XP_Rect* rect,
|
||||||
HintAtts hintAtts )
|
HintAtts hintAtts )
|
||||||
{
|
{
|
||||||
SymDrawCtxt* sctx = (SymDrawCtxt*)p_dctx;
|
SymDrawCtxt* sctx = (SymDrawCtxt*)p_dctx;
|
||||||
XP_UCHAR* arrow = (XP_UCHAR*)(vert? "|":"-");
|
|
||||||
|
|
||||||
XP_LOGF( "drawBoardArrow: %s", arrow );
|
|
||||||
|
|
||||||
#if 0
|
|
||||||
gc.BitBlt( point, arrowBmp );
|
|
||||||
#else
|
|
||||||
TRect lRect;
|
TRect lRect;
|
||||||
symLocalRect( &lRect, rect );
|
symLocalRect( &lRect, rect );
|
||||||
sctx->iGC->SetClippingRect( lRect );
|
sctx->iGC->SetClippingRect( lRect );
|
||||||
|
|
||||||
textInCell( sctx, arrow, &lRect, EFalse );
|
TRgb rgb;
|
||||||
#endif
|
getBonusColor( sctx, bonus, &rgb );
|
||||||
}
|
sctx->iGC->SetBrushColor( rgb );
|
||||||
|
sctx->iGC->SetBrushStyle( CGraphicsContext::ESolidBrush );
|
||||||
|
|
||||||
|
CFbsBitmap* arrow = vert? sctx->iDownArrow : sctx->iRightArrow;
|
||||||
|
drawBitmap( sctx, arrow, &lRect );
|
||||||
|
} /* sym_draw_drawBoardArrow */
|
||||||
|
|
||||||
#ifdef KEY_SUPPORT
|
#ifdef KEY_SUPPORT
|
||||||
static void
|
static void
|
||||||
|
@ -639,8 +670,8 @@ figureFonts( SymDrawCtxt* sctx )
|
||||||
|
|
||||||
for ( TInt i = 0; i < nTypes; ++i ) {
|
for ( TInt i = 0; i < nTypes; ++i ) {
|
||||||
sdev->TypefaceSupport( tfSupport, i );
|
sdev->TypefaceSupport( tfSupport, i );
|
||||||
fontName = tfSupport.iTypeface.iName.Des();
|
|
||||||
#if 0
|
#if 0
|
||||||
|
fontName = tfSupport.iTypeface.iName.Des();
|
||||||
TBuf8<128> tmpb;
|
TBuf8<128> tmpb;
|
||||||
tmpb.Copy( fontName );
|
tmpb.Copy( fontName );
|
||||||
XP_UCHAR buf[128];
|
XP_UCHAR buf[128];
|
||||||
|
@ -725,7 +756,10 @@ sym_drawctxt_make( MPFORMAL CWindowGc* aGC, CCoeEnv* aCoeEnv,
|
||||||
SET_VTABLE_ENTRY( sctx->vtable, draw_destroyCtxt, sym );
|
SET_VTABLE_ENTRY( sctx->vtable, draw_destroyCtxt, sym );
|
||||||
SET_VTABLE_ENTRY( sctx->vtable, draw_boardBegin, sym );
|
SET_VTABLE_ENTRY( sctx->vtable, draw_boardBegin, sym );
|
||||||
SET_VTABLE_ENTRY( sctx->vtable, draw_boardFinished, sym );
|
SET_VTABLE_ENTRY( sctx->vtable, draw_boardFinished, sym );
|
||||||
|
#ifdef DEBUG
|
||||||
|
/* Shouldn't get called as thing stand now */
|
||||||
SET_VTABLE_ENTRY( sctx->vtable, draw_vertScrollBoard, sym );
|
SET_VTABLE_ENTRY( sctx->vtable, draw_vertScrollBoard, sym );
|
||||||
|
#endif
|
||||||
SET_VTABLE_ENTRY( sctx->vtable, draw_trayBegin, sym );
|
SET_VTABLE_ENTRY( sctx->vtable, draw_trayBegin, sym );
|
||||||
SET_VTABLE_ENTRY( sctx->vtable, draw_trayFinished, sym );
|
SET_VTABLE_ENTRY( sctx->vtable, draw_trayFinished, sym );
|
||||||
SET_VTABLE_ENTRY( sctx->vtable, draw_measureRemText, sym );
|
SET_VTABLE_ENTRY( sctx->vtable, draw_measureRemText, sym );
|
||||||
|
@ -768,6 +802,27 @@ sym_drawctxt_make( MPFORMAL CWindowGc* aGC, CCoeEnv* aCoeEnv,
|
||||||
sctx->colors[COLOR_TRPL_WORD] = KRgbCyan;
|
sctx->colors[COLOR_TRPL_WORD] = KRgbCyan;
|
||||||
|
|
||||||
figureFonts( sctx );
|
figureFonts( sctx );
|
||||||
|
|
||||||
|
#if defined DEBUG && defined SERIES_80
|
||||||
|
/* this path will change for other platforms/devices!!! */
|
||||||
|
_LIT( kBitmapsPath, "z:\\system\\apps\\XWORDS\\xwbitmaps.mbm" );
|
||||||
|
TFileName bitmapFile( kBitmapsPath );
|
||||||
|
|
||||||
|
XP_LOGF( "loading bitmaps0" );
|
||||||
|
sctx->iDownArrow = new (ELeave) CFbsBitmap();
|
||||||
|
User::LeaveIfError( sctx->iDownArrow->
|
||||||
|
Load(bitmapFile, EMbmXwbitmapsDownarrow_80 ) );
|
||||||
|
sctx->iRightArrow = new (ELeave) CFbsBitmap();
|
||||||
|
User::LeaveIfError( sctx->iRightArrow->
|
||||||
|
Load(bitmapFile, EMbmXwbitmapsRightarrow_80 ) );
|
||||||
|
sctx->iStar = new (ELeave) CFbsBitmap();
|
||||||
|
User::LeaveIfError( sctx->iStar->
|
||||||
|
Load(bitmapFile, EMbmXwbitmapsStar_80 ) );
|
||||||
|
|
||||||
|
XP_LOGF( "done loading bitmaps" );
|
||||||
|
#else
|
||||||
|
error No bitmaps!!!
|
||||||
|
#endif
|
||||||
} else {
|
} else {
|
||||||
XP_FREE( mpool, sctx );
|
XP_FREE( mpool, sctx );
|
||||||
sctx = NULL;
|
sctx = NULL;
|
||||||
|
|
Loading…
Add table
Reference in a new issue