From effbc3ef00e40fd34a1dbfee2d19c009b3392aa3 Mon Sep 17 00:00:00 2001 From: Eric House Date: Sat, 11 Apr 2020 07:17:22 -0700 Subject: [PATCH] fix crash creating light-colored arrow Changing it to a VectorDrawable meant it crashed code that assumed otherwise. Fix by removing the assumption. --- .../java/org/eehouse/android/xw4/BoardCanvas.java | 14 +++++++++----- 1 file changed, 9 insertions(+), 5 deletions(-) diff --git a/xwords4/android/app/src/main/java/org/eehouse/android/xw4/BoardCanvas.java b/xwords4/android/app/src/main/java/org/eehouse/android/xw4/BoardCanvas.java index b78ca6ee5..fa8a5d67d 100644 --- a/xwords4/android/app/src/main/java/org/eehouse/android/xw4/BoardCanvas.java +++ b/xwords4/android/app/src/main/java/org/eehouse/android/xw4/BoardCanvas.java @@ -919,17 +919,21 @@ public class BoardCanvas extends Canvas implements DrawCtx { Drawable arrow = res.getDrawable( resID ); if ( !useDark ) { - Bitmap src = ((BitmapDrawable)arrow).getBitmap(); - Bitmap bitmap = src.copy( Bitmap.Config.ARGB_8888, true ); + Bitmap bitmap = Bitmap.createBitmap( arrow.getIntrinsicWidth(), + arrow.getIntrinsicHeight(), + Bitmap.Config.ARGB_8888 ); + Canvas canvas = new Canvas( bitmap ); + arrow.setBounds( 0, 0, canvas.getWidth(), canvas.getHeight() ); + arrow.draw( canvas ); + for ( int xx = 0; xx < bitmap.getWidth(); ++xx ) { - for( int yy = 0; yy < bitmap.getHeight(); ++yy ) { + for ( int yy = 0; yy < bitmap.getHeight(); ++yy ) { if ( BLACK == bitmap.getPixel( xx, yy ) ) { bitmap.setPixel( xx, yy, WHITE ); } } } - - arrow = new BitmapDrawable(bitmap); + arrow = new BitmapDrawable( bitmap ); } return arrow; }