mirror of
git://xwords.git.sourceforge.net/gitroot/xwords/xwords
synced 2024-12-30 10:26:58 +01:00
Scale bitmaps for specials to the size of an M so they look right next
to other letters.
This commit is contained in:
parent
a21898894c
commit
ed434c1c67
1 changed files with 52 additions and 41 deletions
|
@ -123,7 +123,8 @@ struct CEDrawCtx {
|
||||||
};
|
};
|
||||||
|
|
||||||
static void ceClearToBkground( CEDrawCtx* dctx, const XP_Rect* rect );
|
static void ceClearToBkground( CEDrawCtx* dctx, const XP_Rect* rect );
|
||||||
static void ceDrawBitmapInRect( HDC hdc, const RECT* r, HBITMAP bitmap );
|
static void ceDrawBitmapInRect( HDC hdc, const RECT* r, HBITMAP bitmap,
|
||||||
|
XP_Bool center, XP_Bool stretch );
|
||||||
static void ceClipToRect( HDC hdc, const RECT* rt );
|
static void ceClipToRect( HDC hdc, const RECT* rt );
|
||||||
static void ceClearFontCache( CEDrawCtx* dctx );
|
static void ceClearFontCache( CEDrawCtx* dctx );
|
||||||
|
|
||||||
|
@ -617,14 +618,15 @@ ceGetSizedFont( CEDrawCtx* dctx, XP_U16 height, XP_U16 width, RFIndex index )
|
||||||
} /* ceGetSizedFont */
|
} /* ceGetSizedFont */
|
||||||
|
|
||||||
static HBITMAP
|
static HBITMAP
|
||||||
checkBMCache( CEDrawCtx* dctx, HDC hdc, const XP_UCHAR* letters, XP_U16 index,
|
checkBMCache( CEDrawCtx* dctx, HDC hdc, const XP_UCHAR* letters,
|
||||||
const XP_Bitmaps* bitmaps, XP_Bool* cached )
|
const XP_U16 index, const XP_Bitmaps* bitmaps, XP_Bool* cached )
|
||||||
{
|
{
|
||||||
HBITMAP bm = NULL;
|
HBITMAP bm = NULL;
|
||||||
CeBMCacheEntry* entry = NULL;
|
CeBMCacheEntry* entry = NULL;
|
||||||
XP_U16 len = 1 + XP_STRLEN( letters );
|
XP_U16 len = 1 + XP_STRLEN( letters );
|
||||||
XP_Bool canCache = XP_FALSE;
|
XP_Bool canCache = XP_FALSE;
|
||||||
|
|
||||||
|
XP_ASSERT( !!letters );
|
||||||
XP_ASSERT( index < 2 );
|
XP_ASSERT( index < 2 );
|
||||||
|
|
||||||
if ( len <= sizeof( entry->letters ) ) {
|
if ( len <= sizeof( entry->letters ) ) {
|
||||||
|
@ -650,7 +652,7 @@ checkBMCache( CEDrawCtx* dctx, HDC hdc, const XP_UCHAR* letters, XP_U16 index,
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
if ( !bm ) {
|
if ( !bm ) {
|
||||||
const CEBitmapInfo* info = (const CEBitmapInfo*)bitmaps->bmps[index];
|
const CEBitmapInfo* info = (const CEBitmapInfo*)(bitmaps->bmps[index]);
|
||||||
XP_U16 nCols, nRows, row, col, rowBytes;
|
XP_U16 nCols, nRows, row, col, rowBytes;
|
||||||
COLORREF black = dctx->globals->appPrefs.colors[CE_BLACK_COLOR];
|
COLORREF black = dctx->globals->appPrefs.colors[CE_BLACK_COLOR];
|
||||||
COLORREF white = dctx->globals->appPrefs.colors[CE_WHITE_COLOR];
|
COLORREF white = dctx->globals->appPrefs.colors[CE_WHITE_COLOR];
|
||||||
|
@ -700,13 +702,13 @@ checkBMCache( CEDrawCtx* dctx, HDC hdc, const XP_UCHAR* letters, XP_U16 index,
|
||||||
|
|
||||||
static void
|
static void
|
||||||
makeAndDrawBitmap( CEDrawCtx* dctx, HDC hdc, const RECT* bnds,
|
makeAndDrawBitmap( CEDrawCtx* dctx, HDC hdc, const RECT* bnds,
|
||||||
const XP_UCHAR* letters, XP_U16 index,
|
const XP_UCHAR* letters, const XP_Bitmaps* bitmaps,
|
||||||
const XP_Bitmaps* bitmaps )
|
XP_U16 index, XP_Bool center )
|
||||||
{
|
{
|
||||||
XP_Bool cached;
|
XP_Bool cached;
|
||||||
HBITMAP bm = checkBMCache( dctx, hdc, letters, index, bitmaps, &cached );
|
HBITMAP bm = checkBMCache( dctx, hdc, letters, index, bitmaps, &cached );
|
||||||
|
|
||||||
ceDrawBitmapInRect( hdc, bnds, bm );
|
ceDrawBitmapInRect( hdc, bnds, bm, center, XP_TRUE );
|
||||||
|
|
||||||
if ( !cached ) {
|
if ( !cached ) {
|
||||||
DeleteObject( bm );
|
DeleteObject( bm );
|
||||||
|
@ -1011,7 +1013,7 @@ DRAW_FUNC_NAME(drawCell)( DrawCtx* p_dctx, const XP_Rect* xprect,
|
||||||
ceSetTextColor( hdc, dctx, foreColorIndx );
|
ceSetTextColor( hdc, dctx, foreColorIndx );
|
||||||
|
|
||||||
if ( !isDragSrc && !!bitmaps ) {
|
if ( !isDragSrc && !!bitmaps ) {
|
||||||
makeAndDrawBitmap( dctx, hdc, &rt, letters, 0, bitmaps );
|
makeAndDrawBitmap( dctx, hdc, &rt, letters, bitmaps, 0, XP_TRUE );
|
||||||
} else if ( !isDragSrc && !!letters && (letters[0] != '\0') ) {
|
} else if ( !isDragSrc && !!letters && (letters[0] != '\0') ) {
|
||||||
wchar_t widebuf[4];
|
wchar_t widebuf[4];
|
||||||
|
|
||||||
|
@ -1021,7 +1023,7 @@ DRAW_FUNC_NAME(drawCell)( DrawCtx* p_dctx, const XP_Rect* xprect,
|
||||||
xprect->top+2, xprect->width, DT_CENTER );
|
xprect->top+2, xprect->width, DT_CENTER );
|
||||||
} else if ( (flags&CELL_ISSTAR) != 0 ) {
|
} else if ( (flags&CELL_ISSTAR) != 0 ) {
|
||||||
ceSetTextColor( hdc, dctx, CE_BLACK_COLOR );
|
ceSetTextColor( hdc, dctx, CE_BLACK_COLOR );
|
||||||
ceDrawBitmapInRect( hdc, &textRect, dctx->origin );
|
ceDrawBitmapInRect( hdc, &textRect, dctx->origin, XP_TRUE, XP_FALSE );
|
||||||
}
|
}
|
||||||
|
|
||||||
ceDrawHintBorders( dctx, xprect, hintAtts );
|
ceDrawHintBorders( dctx, xprect, hintAtts );
|
||||||
|
@ -1140,22 +1142,25 @@ drawDrawTileGuts( DrawCtx* p_dctx, const XP_Rect* xprect,
|
||||||
fce = ceGetSizedFont( dctx, charHt, 0,
|
fce = ceGetSizedFont( dctx, charHt, 0,
|
||||||
valHidden ? RFONTS_TRAYNOVAL:RFONTS_TRAY );
|
valHidden ? RFONTS_TRAYNOVAL:RFONTS_TRAY );
|
||||||
|
|
||||||
if ( !!bitmaps ) {
|
if ( !!bitmaps || !!letters ) {
|
||||||
RECT lrt = { .left = xprect->left,
|
|
||||||
.top = xprect->top,
|
|
||||||
.right = xprect->left + xprect->width - 8,
|
|
||||||
.bottom = xprect->top + fce->glyphHt
|
|
||||||
};
|
|
||||||
makeAndDrawBitmap( dctx, hdc, &lrt, letters, 1, bitmaps );
|
|
||||||
} else if ( !!letters ) {
|
|
||||||
HFONT oldFont = SelectObject( hdc, fce->setFont );
|
HFONT oldFont = SelectObject( hdc, fce->setFont );
|
||||||
MultiByteToWideChar( CP_ACP, MB_PRECOMPOSED, letters, -1,
|
if ( !!bitmaps ) {
|
||||||
widebuf, VSIZE(widebuf) );
|
RECT lrt = { .left = xprect->left + (TRAY_BORDER/2),
|
||||||
|
.top = xprect->top + (TRAY_BORDER/2),
|
||||||
|
.right = xprect->left + charHt,
|
||||||
|
.bottom = xprect->top + fce->glyphHt
|
||||||
|
};
|
||||||
|
makeAndDrawBitmap( dctx, hdc, &lrt, letters, bitmaps, 1,
|
||||||
|
XP_FALSE );
|
||||||
|
} else if ( !!letters ) {
|
||||||
|
MultiByteToWideChar( CP_ACP, MB_PRECOMPOSED, letters, -1,
|
||||||
|
widebuf, VSIZE(widebuf) );
|
||||||
|
|
||||||
ceDrawTextClipped( hdc, widebuf, -1, XP_TRUE, fce,
|
ceDrawTextClipped( hdc, widebuf, -1, XP_TRUE, fce,
|
||||||
xprect->left + 4, xprect->top + 4,
|
xprect->left + 4, xprect->top + 4,
|
||||||
xprect->width - 8,
|
xprect->width - 8,
|
||||||
valHidden?DT_CENTER:DT_LEFT );
|
valHidden?DT_CENTER:DT_LEFT );
|
||||||
|
}
|
||||||
SelectObject( hdc, oldFont );
|
SelectObject( hdc, oldFont );
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1244,7 +1249,8 @@ ceClearToBkground( CEDrawCtx* dctx, const XP_Rect* rect )
|
||||||
* change the proportions.
|
* change the proportions.
|
||||||
*/
|
*/
|
||||||
static void
|
static void
|
||||||
ceDrawBitmapInRect( HDC hdc, const RECT* rect, HBITMAP bitmap )
|
ceDrawBitmapInRect( HDC hdc, const RECT* rect, HBITMAP bitmap,
|
||||||
|
XP_Bool center, XP_Bool stretch )
|
||||||
{
|
{
|
||||||
BITMAP bmp;
|
BITMAP bmp;
|
||||||
int nBytes;
|
int nBytes;
|
||||||
|
@ -1259,19 +1265,25 @@ ceDrawBitmapInRect( HDC hdc, const RECT* rect, HBITMAP bitmap )
|
||||||
int top = rect->top;
|
int top = rect->top;
|
||||||
XP_U16 width = rect->right - left;
|
XP_U16 width = rect->right - left;
|
||||||
XP_U16 height = rect->bottom - top;
|
XP_U16 height = rect->bottom - top;
|
||||||
XP_U16 ii;
|
|
||||||
HDC tmpDC;
|
HDC tmpDC;
|
||||||
|
|
||||||
for ( ii = 1;
|
if ( stretch ) {
|
||||||
((bmp.bmWidth * ii) <= width) && ((bmp.bmHeight * ii) <= height);
|
/* Target rect size is based on width of M in the current font */
|
||||||
++ii ) {
|
SIZE size;
|
||||||
/* do nothing */
|
GetTextExtentPoint32( hdc, L"M", 1, &size );
|
||||||
}
|
width = height = size.cx; /* make it square */
|
||||||
|
} else {
|
||||||
|
/* Find dimensions that'll fit multiplying an integral number of
|
||||||
|
times */
|
||||||
|
XP_U16 factor = XP_MIN( width/bmp.bmWidth, height/bmp.bmHeight );
|
||||||
|
if ( factor == 0 ) {
|
||||||
|
XP_LOGF( "%s: cell at %dx%d too small for bitmap at %ldx%ld",
|
||||||
|
__func__, width, height, bmp.bmWidth, bmp.bmHeight );
|
||||||
|
factor = 1;
|
||||||
|
}
|
||||||
|
|
||||||
if ( --ii == 0 ) {
|
width = bmp.bmWidth * factor;
|
||||||
XP_LOGF( "%s: cell at %dx%d too small for bitmap at %ldx%ld",
|
height = bmp.bmHeight * factor;
|
||||||
__func__, width, height, bmp.bmWidth, bmp.bmHeight );
|
|
||||||
ii = 1;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
tmpDC = CreateCompatibleDC( hdc );
|
tmpDC = CreateCompatibleDC( hdc );
|
||||||
|
@ -1279,11 +1291,10 @@ ceDrawBitmapInRect( HDC hdc, const RECT* rect, HBITMAP bitmap )
|
||||||
|
|
||||||
(void)IntersectClipRect( tmpDC, left, top, rect->right, rect->bottom );
|
(void)IntersectClipRect( tmpDC, left, top, rect->right, rect->bottom );
|
||||||
|
|
||||||
width = bmp.bmWidth * ii;
|
if ( center ) {
|
||||||
height = bmp.bmHeight * ii;
|
left += ((rect->right - left) - width) / 2;
|
||||||
|
top += ((rect->bottom - top) - height) / 2;
|
||||||
left += ((rect->right - left) - width) / 2;
|
}
|
||||||
top += ((rect->bottom - top) - height) / 2;
|
|
||||||
|
|
||||||
StretchBlt( hdc, left, top, width, height,
|
StretchBlt( hdc, left, top, width, height,
|
||||||
tmpDC, 0, 0, bmp.bmWidth, bmp.bmHeight, SRCCOPY );
|
tmpDC, 0, 0, bmp.bmWidth, bmp.bmHeight, SRCCOPY );
|
||||||
|
@ -1329,7 +1340,7 @@ DRAW_FUNC_NAME(drawBoardArrow)( DrawCtx* p_dctx, const XP_Rect* xprect,
|
||||||
ceSetBkColor( hdc, dctx, bkIndex );
|
ceSetBkColor( hdc, dctx, bkIndex );
|
||||||
ceSetTextColor( hdc, dctx, CE_BLACK_COLOR );
|
ceSetTextColor( hdc, dctx, CE_BLACK_COLOR );
|
||||||
|
|
||||||
ceDrawBitmapInRect( hdc, &rt, cursor );
|
ceDrawBitmapInRect( hdc, &rt, cursor, XP_TRUE, XP_FALSE );
|
||||||
|
|
||||||
ceDrawHintBorders( dctx, xprect, hintAtts );
|
ceDrawHintBorders( dctx, xprect, hintAtts );
|
||||||
} /* ce_draw_drawBoardArrow */
|
} /* ce_draw_drawBoardArrow */
|
||||||
|
|
Loading…
Reference in a new issue