override onMeasure to make BoardView only as large as it needs to be

so that on tall narrow screens (e.g. Kindle Fire) there's no white
space between the tray and the buttons.
This commit is contained in:
Eric House 2012-07-01 12:54:38 -07:00
parent 03f4236240
commit 2ae6bd8caf
2 changed files with 78 additions and 8 deletions

View file

@ -9,7 +9,7 @@
<org.eehouse.android.xw4.BoardView <org.eehouse.android.xw4.BoardView
android:id="@+id/board_view" android:id="@+id/board_view"
android:layout_width="fill_parent" android:layout_width="fill_parent"
android:layout_height="fill_parent" android:layout_height="wrap_content"
android:layout_weight="1" android:layout_weight="1"
android:focusable="true" android:focusable="true"
android:clickable="true" android:clickable="true"

View file

@ -240,6 +240,78 @@ public class BoardView extends View implements DrawCtx, BoardHandler,
return true; // required to get subsequent events return true; // required to get subsequent events
} }
// private void printMode( String comment, int mode )
// {
// comment += ": ";
// switch( mode ) {
// case View.MeasureSpec.AT_MOST:
// comment += "AT_MOST";
// break;
// case View.MeasureSpec.EXACTLY:
// comment += "EXACTLY";
// break;
// case View.MeasureSpec.UNSPECIFIED:
// comment += "UNSPECIFIED";
// break;
// default:
// comment += "<bogus>";
// }
// DbgUtils.logf( comment );
// }
@Override
protected void onMeasure( int widthMeasureSpec, int heightMeasureSpec )
{
// One of the android sample apps ignores mode entirely:
// int w = MeasureSpec.getSize(widthMeasureSpec);
// int h = MeasureSpec.getSize(heightMeasureSpec);
// int d = w == 0 ? h : h == 0 ? w : w < h ? w : h;
// setMeasuredDimension(d, d);
int width = View.MeasureSpec.getSize( widthMeasureSpec );
int height = View.MeasureSpec.getSize( heightMeasureSpec );
int heightMode = View.MeasureSpec.getMode( heightMeasureSpec );
// printMode( "heightMode", heightMode );
BoardDims dims = figureBoardDims( width, height );
// If I let the spec tell me whether I can reduce the width
// then I don't change it on the second pass, but if I ignore
// that it works (even though the docs say my change is what
// will be ignored.) I'm probably specifying something
// incorrectly in the layout xml file.
if ( false ) {
height = resolveSize( dims.height, heightMeasureSpec );
width = resolveSize( dims.width, widthMeasureSpec );
} else {
height = dims.height;
}
int minHeight = getSuggestedMinimumHeight();
if ( height < minHeight ) {
height = minHeight;
}
setMeasuredDimension( width, height );
}
// @Override
// protected void onLayout( boolean changed, int left, int top,
// int right, int bottom )
// {
// DbgUtils.logf( "BoardView.onLayout(%b, %d, %d, %d, %d)",
// changed, left, top, right, bottom );
// super.onLayout( changed, left, top, right, bottom );
// }
// @Override
// protected void onSizeChanged( int width, int height,
// int oldWidth, int oldHeight )
// {
// DbgUtils.logf( "BoardView.onSizeChanged(%d,%d,%d,%d)", width, height,
// oldWidth, oldHeight );
// super.onSizeChanged( width, height, oldWidth, oldHeight );
// }
// This will be called from the UI thread // This will be called from the UI thread
@Override @Override
protected void onDraw( Canvas canvas ) protected void onDraw( Canvas canvas )
@ -252,14 +324,14 @@ public class BoardView extends View implements DrawCtx, BoardHandler,
} }
} }
private BoardDims figureBoardDims( int width, int height, private BoardDims figureBoardDims( int width, int height )
CurGameInfo gi )
{ {
BoardDims result = new BoardDims(); BoardDims result = new BoardDims();
result.width = width; result.width = width;
result.left = 0; result.left = 0;
result.top = 0;
int nCells = gi.boardSize; int nCells = m_gi.boardSize;
int cellSize = width / nCells; int cellSize = width / nCells;
int maxCellSize = 4 * m_defaultFontHt; int maxCellSize = 4 * m_defaultFontHt;
if ( cellSize > maxCellSize ) { if ( cellSize > maxCellSize ) {
@ -296,9 +368,7 @@ public class BoardView extends View implements DrawCtx, BoardHandler,
trayHt += heightLeft * 2; trayHt += heightLeft * 2;
scoreHt += heightLeft; scoreHt += heightLeft;
heightUsed = trayHt + scoreHt + ((nCells - nToScroll) * cellSize); heightUsed = trayHt + scoreHt + ((nCells - nToScroll) * cellSize);
heightLeft = height - heightUsed;
} }
result.top = heightLeft / 2;
result.trayHt = trayHt; result.trayHt = trayHt;
result.scoreHt = scoreHt; result.scoreHt = scoreHt;
@ -308,7 +378,7 @@ public class BoardView extends View implements DrawCtx, BoardHandler,
result.height = heightUsed; result.height = heightUsed;
result.cellSize = cellSize; result.cellSize = cellSize;
if ( gi.timerEnabled ) { if ( m_gi.timerEnabled ) {
Paint paint = new Paint(); Paint paint = new Paint();
paint.setTextSize( m_mediumFontHt ); paint.setTextSize( m_mediumFontHt );
paint.getTextBounds( "-00:00", 0, 6, m_boundsScratch ); paint.getTextBounds( "-00:00", 0, 6, m_boundsScratch );
@ -334,7 +404,7 @@ public class BoardView extends View implements DrawCtx, BoardHandler,
m_letterRect = null; m_letterRect = null;
m_valRect = null; m_valRect = null;
BoardDims dims = figureBoardDims( width, height, m_gi ); BoardDims dims = figureBoardDims( width, height );
m_left = dims.left; m_left = dims.left;
m_top = dims.top; m_top = dims.top;