mirror of
git://xwords.git.sourceforge.net/gitroot/xwords/xwords
synced 2025-01-18 22:26:30 +01:00
fix NPE by refusing to calc font info when don't have char set, and by
resusing to draw when don't have font info. Until other bugs got fixed this must meant lots of all-white boards, and it's not strictly necessary, but is an improvement.
This commit is contained in:
parent
09100dcb2c
commit
2572af039d
1 changed files with 81 additions and 75 deletions
|
@ -463,67 +463,68 @@ public class BoardView extends View implements DrawCtx, BoardHandler,
|
||||||
public boolean drawCell( final Rect rect, String text, int tile, int owner,
|
public boolean drawCell( final Rect rect, String text, int tile, int owner,
|
||||||
int bonus, int hintAtts, final int flags )
|
int bonus, int hintAtts, final int flags )
|
||||||
{
|
{
|
||||||
int backColor;
|
boolean canDraw = figureFontDims();
|
||||||
boolean empty = 0 != (flags & (CELL_DRAGSRC|CELL_ISEMPTY));
|
if ( canDraw ) {
|
||||||
boolean pending = 0 != (flags & CELL_HIGHLIGHT);
|
int backColor;
|
||||||
String bonusStr = null;
|
boolean empty = 0 != (flags & (CELL_DRAGSRC|CELL_ISEMPTY));
|
||||||
|
boolean pending = 0 != (flags & CELL_HIGHLIGHT);
|
||||||
|
String bonusStr = null;
|
||||||
|
|
||||||
figureFontDims();
|
|
||||||
|
|
||||||
if ( owner < 0 ) {
|
if ( owner < 0 ) {
|
||||||
owner = 0;
|
owner = 0;
|
||||||
}
|
}
|
||||||
int foreColor = m_playerColors[owner];
|
int foreColor = m_playerColors[owner];
|
||||||
|
|
||||||
if ( 0 != (flags & CELL_ISCURSOR) ) {
|
if ( 0 != (flags & CELL_ISCURSOR) ) {
|
||||||
backColor = m_otherColors[CommonPrefs.COLOR_FOCUS];
|
backColor = m_otherColors[CommonPrefs.COLOR_FOCUS];
|
||||||
} else if ( empty ) {
|
} else if ( empty ) {
|
||||||
if ( 0 == bonus ) {
|
if ( 0 == bonus ) {
|
||||||
backColor = m_otherColors[CommonPrefs.COLOR_NOTILE];
|
backColor = m_otherColors[CommonPrefs.COLOR_NOTILE];
|
||||||
|
} else {
|
||||||
|
backColor = m_bonusColors[bonus];
|
||||||
|
bonusStr = m_bonusSummaries[bonus];
|
||||||
|
}
|
||||||
|
} else if ( pending ) {
|
||||||
|
if ( darkOnLight() ) {
|
||||||
|
foreColor = WHITE;
|
||||||
|
backColor = BLACK;
|
||||||
|
} else {
|
||||||
|
foreColor = BLACK;
|
||||||
|
backColor = WHITE;
|
||||||
|
}
|
||||||
} else {
|
} else {
|
||||||
backColor = m_bonusColors[bonus];
|
backColor = m_otherColors[CommonPrefs.COLOR_TILE_BACK];
|
||||||
bonusStr = m_bonusSummaries[bonus];
|
|
||||||
}
|
}
|
||||||
} else if ( pending ) {
|
|
||||||
if ( darkOnLight() ) {
|
fillRect( rect, backColor );
|
||||||
foreColor = WHITE;
|
|
||||||
backColor = BLACK;
|
if ( empty ) {
|
||||||
|
if ( (CELL_ISSTAR & flags) != 0 ) {
|
||||||
|
m_origin.setBounds( rect );
|
||||||
|
m_origin.draw( m_canvas );
|
||||||
|
} else if ( null != bonusStr ) {
|
||||||
|
m_fillPaint.setColor( GREY );
|
||||||
|
Rect brect = new Rect( rect );
|
||||||
|
brect.inset( 0, brect.height()/10 );
|
||||||
|
drawCentered( bonusStr, brect, m_fontDims );
|
||||||
|
}
|
||||||
} else {
|
} else {
|
||||||
foreColor = BLACK;
|
m_fillPaint.setColor( foreColor );
|
||||||
backColor = WHITE;
|
drawCentered( text, rect, m_fontDims );
|
||||||
}
|
}
|
||||||
} else {
|
|
||||||
backColor = m_otherColors[CommonPrefs.COLOR_TILE_BACK];
|
|
||||||
}
|
|
||||||
|
|
||||||
fillRect( rect, backColor );
|
if ( (CELL_ISBLANK & flags) != 0 ) {
|
||||||
|
markBlank( rect, pending );
|
||||||
if ( empty ) {
|
|
||||||
if ( (CELL_ISSTAR & flags) != 0 ) {
|
|
||||||
m_origin.setBounds( rect );
|
|
||||||
m_origin.draw( m_canvas );
|
|
||||||
} else if ( null != bonusStr ) {
|
|
||||||
m_fillPaint.setColor( GREY );
|
|
||||||
Rect brect = new Rect( rect );
|
|
||||||
brect.inset( 0, brect.height()/10 );
|
|
||||||
drawCentered( bonusStr, brect, m_fontDims );
|
|
||||||
}
|
}
|
||||||
} else {
|
|
||||||
m_fillPaint.setColor( foreColor );
|
// frame the cell
|
||||||
drawCentered( text, rect, m_fontDims );
|
m_strokePaint.setColor( FRAME_GREY );
|
||||||
|
m_canvas.drawRect( rect, m_strokePaint );
|
||||||
|
|
||||||
|
drawCrosshairs( rect, flags );
|
||||||
}
|
}
|
||||||
|
return canDraw;
|
||||||
if ( (CELL_ISBLANK & flags) != 0 ) {
|
|
||||||
markBlank( rect, pending );
|
|
||||||
}
|
|
||||||
|
|
||||||
// frame the cell
|
|
||||||
m_strokePaint.setColor( FRAME_GREY );
|
|
||||||
m_canvas.drawRect( rect, m_strokePaint );
|
|
||||||
|
|
||||||
drawCrosshairs( rect, flags );
|
|
||||||
|
|
||||||
return true;
|
|
||||||
} // drawCell
|
} // drawCell
|
||||||
|
|
||||||
private boolean m_arrowHintShown = false;
|
private boolean m_arrowHintShown = false;
|
||||||
|
@ -710,8 +711,11 @@ public class BoardView extends View implements DrawCtx, BoardHandler,
|
||||||
public void dictChanged( int playerNum, int dictPtr )
|
public void dictChanged( int playerNum, int dictPtr )
|
||||||
{
|
{
|
||||||
if ( m_dictPtr != dictPtr ) {
|
if ( m_dictPtr != dictPtr ) {
|
||||||
if ( m_dictPtr == 0 ||
|
if ( 0 == dictPtr ) {
|
||||||
!XwJNI.dict_tilesAreSame( m_dictPtr, dictPtr ) ) {
|
m_fontDims = null;
|
||||||
|
m_dictChars = null;
|
||||||
|
} else if ( m_dictPtr == 0 ||
|
||||||
|
!XwJNI.dict_tilesAreSame( m_dictPtr, dictPtr ) ) {
|
||||||
m_fontDims = null;
|
m_fontDims = null;
|
||||||
m_dictChars = XwJNI.dict_getChars( dictPtr );
|
m_dictChars = XwJNI.dict_getChars( dictPtr );
|
||||||
}
|
}
|
||||||
|
@ -807,29 +811,29 @@ public class BoardView extends View implements DrawCtx, BoardHandler,
|
||||||
|
|
||||||
private void positionDrawTile( final Rect rect, String text, int val )
|
private void positionDrawTile( final Rect rect, String text, int val )
|
||||||
{
|
{
|
||||||
figureFontDims();
|
if ( figureFontDims() ) {
|
||||||
|
if ( null != text ) {
|
||||||
if ( null != text ) {
|
if ( null == m_letterRect ) {
|
||||||
if ( null == m_letterRect ) {
|
m_letterRect = new Rect( 0, 0, rect.width() * 3 / 4,
|
||||||
m_letterRect = new Rect( 0, 0, rect.width() * 3 / 4,
|
rect.height() * 3 / 4 );
|
||||||
rect.height() * 3 / 4 );
|
}
|
||||||
|
m_letterRect.offsetTo( rect.left+2, rect.top+2 );
|
||||||
|
drawCentered( text, m_letterRect, m_fontDims );
|
||||||
}
|
}
|
||||||
m_letterRect.offsetTo( rect.left+2, rect.top+2 );
|
|
||||||
drawCentered( text, m_letterRect, m_fontDims );
|
|
||||||
}
|
|
||||||
|
|
||||||
if ( val >= 0 ) {
|
if ( val >= 0 ) {
|
||||||
if ( null == m_valRect ) {
|
if ( null == m_valRect ) {
|
||||||
m_valRect = new Rect( 0, 0, rect.width() / 4, rect.height() / 4 );
|
m_valRect = new Rect( 0, 0, rect.width() / 4, rect.height() / 4 );
|
||||||
m_valRect.inset( 2, 2 );
|
m_valRect.inset( 2, 2 );
|
||||||
|
}
|
||||||
|
m_valRect.offsetTo( rect.right - (rect.width() / 4),
|
||||||
|
rect.bottom - (rect.height() / 4) );
|
||||||
|
text = String.format( "%d", val );
|
||||||
|
m_fillPaint.setTextSize( m_valRect.height() );
|
||||||
|
m_fillPaint.setTextAlign( Paint.Align.RIGHT );
|
||||||
|
m_canvas.drawText( text, m_valRect.right, m_valRect.bottom,
|
||||||
|
m_fillPaint );
|
||||||
}
|
}
|
||||||
m_valRect.offsetTo( rect.right - (rect.width() / 4),
|
|
||||||
rect.bottom - (rect.height() / 4) );
|
|
||||||
text = String.format( "%d", val );
|
|
||||||
m_fillPaint.setTextSize( m_valRect.height() );
|
|
||||||
m_fillPaint.setTextAlign( Paint.Align.RIGHT );
|
|
||||||
m_canvas.drawText( text, m_valRect.right, m_valRect.bottom,
|
|
||||||
m_fillPaint );
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -859,9 +863,10 @@ public class BoardView extends View implements DrawCtx, BoardHandler,
|
||||||
m_canvas.drawRect( rect, m_fillPaint );
|
m_canvas.drawRect( rect, m_fillPaint );
|
||||||
}
|
}
|
||||||
|
|
||||||
private void figureFontDims()
|
private boolean figureFontDims()
|
||||||
{
|
{
|
||||||
if ( null == m_fontDims ) {
|
if ( null == m_fontDims && null != m_dictChars ) {
|
||||||
|
|
||||||
final int ht = 24;
|
final int ht = 24;
|
||||||
final int width = 20;
|
final int width = 20;
|
||||||
|
|
||||||
|
@ -928,6 +933,7 @@ public class BoardView extends View implements DrawCtx, BoardHandler,
|
||||||
|
|
||||||
m_fontDims = new FontDims( ht, topRow, bottomRow, maxWidth );
|
m_fontDims = new FontDims( ht, topRow, bottomRow, maxWidth );
|
||||||
}
|
}
|
||||||
|
return null != m_fontDims;
|
||||||
} // figureFontDims
|
} // figureFontDims
|
||||||
|
|
||||||
private void markBlank( final Rect rect, boolean whiteOnBlack )
|
private void markBlank( final Rect rect, boolean whiteOnBlack )
|
||||||
|
|
Loading…
Reference in a new issue