From 83bb4bbd21e910c51536a0317be1f2f04fae292e Mon Sep 17 00:00:00 2001 From: npomfret Date: Thu, 18 Aug 2016 12:02:57 +0100 Subject: [PATCH] reduced memory footprint by using inSampleSize --- .../bamlab/rnimageresizer/ImageResizer.java | 45 +++++++++++++++++-- 1 file changed, 41 insertions(+), 4 deletions(-) diff --git a/android/src/main/java/fr/bamlab/rnimageresizer/ImageResizer.java b/android/src/main/java/fr/bamlab/rnimageresizer/ImageResizer.java index 7049f38..cde9f7c 100644 --- a/android/src/main/java/fr/bamlab/rnimageresizer/ImageResizer.java +++ b/android/src/main/java/fr/bamlab/rnimageresizer/ImageResizer.java @@ -154,15 +154,30 @@ class ImageResizer { int quality, int rotation, String outputPath) throws IOException { + BitmapFactory.Options options = new BitmapFactory.Options(); + options.inJustDecodeBounds = true; + + // find the size of the source image in order to calc the sampleSize + if (!imagePath.startsWith("content://") && !imagePath.startsWith("file://")) { + BitmapFactory.decodeFile(imagePath, options); + } else { + InputStream input = context.getContentResolver().openInputStream(Uri.parse(imagePath)); + BitmapFactory.decodeStream(input, null, options); + input.close(); + } + + //setting a sample size above 1 saves memory + options.inSampleSize = calculateInSampleSize(options, newWidth, newHeight); + options.inJustDecodeBounds = false; Bitmap sourceImage; if (!imagePath.startsWith("content://") && !imagePath.startsWith("file://")) { - sourceImage = BitmapFactory.decodeFile(imagePath); + sourceImage = BitmapFactory.decodeFile(imagePath, options); } else { ContentResolver cr = context.getContentResolver(); - Uri url = Uri.parse(imagePath); - InputStream input = cr.openInputStream(url); - sourceImage = BitmapFactory.decodeStream(input); + + InputStream input = cr.openInputStream(Uri.parse(imagePath)); + sourceImage = BitmapFactory.decodeStream(input, null, options); input.close(); } @@ -199,4 +214,26 @@ class ImageResizer { return resizedImagePath; } + + private static int calculateInSampleSize(BitmapFactory.Options options, int reqWidth, int reqHeight) { + // copied from https://developer.android.com/training/displaying-bitmaps/load-bitmap.html + + final int height = options.outHeight; + final int width = options.outWidth; + + int inSampleSize = 1; + + if (height > reqHeight || width > reqWidth) { + final int halfHeight = height / 2; + final int halfWidth = width / 2; + + // Calculate the largest inSampleSize value that is a power of 2 and keeps both + // height and width larger than the requested height and width. + while ((halfHeight / inSampleSize) >= reqHeight && (halfWidth / inSampleSize) >= reqWidth) { + inSampleSize *= 2; + } + } + + return inSampleSize; + } }