use bitmaps for arrows and star

This commit is contained in:
ehouse 2005-01-08 18:19:12 +00:00
parent 5eee1c702e
commit d36351feb0

View file

@ -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;