diff options
Diffstat (limited to 'src')
-rw-r--r-- | src/com/android/camera/BitmapManager.java | 1 | ||||
-rw-r--r-- | src/com/android/camera/Util.java | 30 | ||||
-rw-r--r-- | src/com/android/camera/gallery/BaseImageList.java | 7 | ||||
-rw-r--r-- | src/com/android/camera/gallery/DrmImageList.java | 4 | ||||
-rw-r--r-- | src/com/android/camera/gallery/IImage.java | 3 | ||||
-rw-r--r-- | src/com/android/camera/gallery/Image.java | 4 | ||||
-rw-r--r-- | src/com/android/camera/gallery/UriImage.java | 2 | ||||
-rw-r--r-- | src/com/android/camera/gallery/VideoObject.java | 3 |
8 files changed, 39 insertions, 15 deletions
diff --git a/src/com/android/camera/BitmapManager.java b/src/com/android/camera/BitmapManager.java index eb05d3e..cb327e8 100644 --- a/src/com/android/camera/BitmapManager.java +++ b/src/com/android/camera/BitmapManager.java @@ -22,7 +22,6 @@ import android.util.Log; import java.io.FileDescriptor; import java.util.Iterator; -import java.util.Map; import java.util.WeakHashMap; /** diff --git a/src/com/android/camera/Util.java b/src/com/android/camera/Util.java index 9e5c74e..61e1923 100644 --- a/src/com/android/camera/Util.java +++ b/src/com/android/camera/Util.java @@ -74,18 +74,42 @@ public class Util { /* * Compute the sample size as a function of minSideLength * and maxNumOfPixels. - * minSideLength is used to specify that minimal width or height of a bitmap. - * maxNumOfPixels is used to specify the maximal size in pixels that are tolerable - * in terms of memory usage. + * minSideLength is used to specify that minimal width or height of a + * bitmap. + * maxNumOfPixels is used to specify the maximal size in pixels that is + * tolerable in terms of memory usage. * * The function returns a sample size based on the constraints. * Both size and minSideLength can be passed in as IImage.UNCONSTRAINED, * which indicates no care of the corresponding constraint. * The functions prefers returning a sample size that * generates a smaller bitmap, unless minSideLength = IImage.UNCONSTRAINED. + * + * Also, the function rounds up the sample size to a power of 2 or multiple + * of 8 because BitmapFactory only honors sample size this way. + * For example, BitmapFactory downsamples an image by 2 even though the + * request is 3. So we round up the sample size to avoid OOM. */ public static int computeSampleSize(BitmapFactory.Options options, int minSideLength, int maxNumOfPixels) { + int initialSize = computeInitialSampleSize(options, minSideLength, + maxNumOfPixels); + + int roundedSize; + if (initialSize <= 8 ) { + roundedSize = 1; + while (roundedSize < initialSize) { + roundedSize <<= 1; + } + } else { + roundedSize = (initialSize + 7) / 8 * 8; + } + + return roundedSize; + } + + private static int computeInitialSampleSize(BitmapFactory.Options options, + int minSideLength, int maxNumOfPixels) { double w = options.outWidth; double h = options.outHeight; diff --git a/src/com/android/camera/gallery/BaseImageList.java b/src/com/android/camera/gallery/BaseImageList.java index 55a12c0..b440130 100644 --- a/src/com/android/camera/gallery/BaseImageList.java +++ b/src/com/android/camera/gallery/BaseImageList.java @@ -231,7 +231,8 @@ public abstract class BaseImageList implements IImageList { // and is significantly faster. options.inSampleSize = Util.computeSampleSize(options, - IImage.MINI_THUMB_TARGET_SIZE, IImage.UNCONSTRAINED); + IImage.MINI_THUMB_TARGET_SIZE, + IImage.MINI_THUMB_MAX_NUM_PIXELS); options.inDither = false; options.inPreferredConfig = Bitmap.Config.ARGB_8888; options.inJustDecodeBounds = false; @@ -246,12 +247,12 @@ public abstract class BaseImageList implements IImageList { // create the minithumb from it. private Bitmap createThumbnailFromUri(Uri uri, long id) { Bitmap bitmap = Util.makeBitmap(IImage.THUMBNAIL_TARGET_SIZE, - IImage.UNCONSTRAINED, uri, mContentResolver); + IImage.THUMBNAIL_MAX_NUM_PIXELS, uri, mContentResolver); if (bitmap != null) { storeThumbnail(bitmap, id); } else { bitmap = Util.makeBitmap(IImage.MINI_THUMB_TARGET_SIZE, - IImage.UNCONSTRAINED, uri, mContentResolver); + IImage.MINI_THUMB_MAX_NUM_PIXELS, uri, mContentResolver); } return bitmap; } diff --git a/src/com/android/camera/gallery/DrmImageList.java b/src/com/android/camera/gallery/DrmImageList.java index 445d867..feea00c 100644 --- a/src/com/android/camera/gallery/DrmImageList.java +++ b/src/com/android/camera/gallery/DrmImageList.java @@ -99,13 +99,13 @@ public class DrmImageList extends ImageList implements IImageList { @Override public Bitmap miniThumbBitmap() { return fullSizeBitmap(IImage.MINI_THUMB_TARGET_SIZE, - IImage.UNCONSTRAINED); + IImage.MINI_THUMB_MAX_NUM_PIXELS); } @Override public Bitmap thumbBitmap(boolean rotateAsNeeded) { return fullSizeBitmap(IImage.THUMBNAIL_TARGET_SIZE, - IImage.UNCONSTRAINED); + IImage.THUMBNAIL_MAX_NUM_PIXELS); } @Override diff --git a/src/com/android/camera/gallery/IImage.java b/src/com/android/camera/gallery/IImage.java index 50a3aba..f93d539 100644 --- a/src/com/android/camera/gallery/IImage.java +++ b/src/com/android/camera/gallery/IImage.java @@ -17,7 +17,6 @@ package com.android.camera.gallery; import android.graphics.Bitmap; -import android.graphics.BitmapFactory; import android.net.Uri; import java.io.InputStream; @@ -28,6 +27,8 @@ import java.io.InputStream; public interface IImage { static final int THUMBNAIL_TARGET_SIZE = 320; static final int MINI_THUMB_TARGET_SIZE = 96; + static final int THUMBNAIL_MAX_NUM_PIXELS = 512 * 384; + static final int MINI_THUMB_MAX_NUM_PIXELS = 128 * 128; static final int UNCONSTRAINED = -1; /** Get the image list which contains this image. */ diff --git a/src/com/android/camera/gallery/Image.java b/src/com/android/camera/gallery/Image.java index aab9545..3102a7b 100644 --- a/src/com/android/camera/gallery/Image.java +++ b/src/com/android/camera/gallery/Image.java @@ -217,8 +217,8 @@ public class Image extends BaseImage implements IImage { } if (bitmap == null) { - bitmap = fullSizeBitmap(THUMBNAIL_TARGET_SIZE, IImage.UNCONSTRAINED, - IImage.NO_ROTATE, IImage.NO_NATIVE); + bitmap = fullSizeBitmap(THUMBNAIL_TARGET_SIZE, + THUMBNAIL_MAX_NUM_PIXELS, NO_ROTATE, NO_NATIVE); // No thumbnail found... storing the new one. bitmap = mContainer.storeThumbnail(bitmap, mId); } diff --git a/src/com/android/camera/gallery/UriImage.java b/src/com/android/camera/gallery/UriImage.java index a53dd79..e09dae7 100644 --- a/src/com/android/camera/gallery/UriImage.java +++ b/src/com/android/camera/gallery/UriImage.java @@ -122,7 +122,7 @@ class UriImage implements IImage { } public Bitmap thumbBitmap(boolean rotateAsNeeded) { - return fullSizeBitmap(THUMBNAIL_TARGET_SIZE, IImage.UNCONSTRAINED, + return fullSizeBitmap(THUMBNAIL_TARGET_SIZE, THUMBNAIL_MAX_NUM_PIXELS, rotateAsNeeded); } diff --git a/src/com/android/camera/gallery/VideoObject.java b/src/com/android/camera/gallery/VideoObject.java index bb499f9..61dbd8e 100644 --- a/src/com/android/camera/gallery/VideoObject.java +++ b/src/com/android/camera/gallery/VideoObject.java @@ -20,7 +20,6 @@ import com.android.camera.Util; import android.content.ContentResolver; import android.graphics.Bitmap; -import android.graphics.BitmapFactory; import android.net.Uri; import java.io.IOException; @@ -108,7 +107,7 @@ public class VideoObject extends BaseImage implements IImage { } public Bitmap thumbBitmap(boolean rotateAsNeeded) { - return fullSizeBitmap(THUMBNAIL_TARGET_SIZE, UNCONSTRAINED); + return fullSizeBitmap(THUMBNAIL_TARGET_SIZE, THUMBNAIL_MAX_NUM_PIXELS); } @Override |