Quantcast
Channel: Recent Threads — Xamarin Community Forums
Viewing all articles
Browse latest Browse all 204402

Android - OutOfMemory Exception

$
0
0

The issue I'm facing is the DalvikVM heap size produces an OutOfMemoryException when I use bitmaps.

I’ve implemented the IDisposable pattern to use of bitmaps

using (var bmp = ImageResizer.DecodeSampledBitmapFromResource (Resources, Resource.Drawable.exampleImage, 
    Resources.DisplayMetrics.WidthPixels / 2, (int)((Resources.DisplayMetrics.WidthPixels / 2) * _aspect)))
{
    _btnFoo.SetImageBitmap (bmp);
    bmp.Dispose ();
}

public static class ImageResizer
{
    public static int CalculateInSampleSize(BitmapFactory.Options options, int reqWidth, int reqHeight)
    {
        // Raw height and width of image
        var height = (float)options.OutHeight;
        var width = (float)options.OutWidth;
        var inSampleSize = 1D;
        if (height > reqHeight || width > reqWidth)
        {
        inSampleSize = width > height
            ? height/reqHeight
            : width/reqWidth;
        }
        return (int) inSampleSize;
    }

    public static Bitmap DecodeSampledBitmapFromResource(Resources res, int resId, int reqWidth, int reqHeight)
    {
        var options = new BitmapFactory.Options {
        InJustDecodeBounds = true,
        };
        using (var dispose = BitmapFactory.DecodeResource(res, resId, options)) {
        }
        options.InSampleSize = CalculateInSampleSize(options, reqWidth, reqHeight);
        options.InJustDecodeBounds = false;
        return BitmapFactory.DecodeResource(res, resId, options);
    }
}

Implementing this fix has helped with some of the issues however the app crashes only on a Galaxy S4 when the third bitmap is used which was happening before the above fix.

See below the stack trace for the crash.

I/dalvikvm-heap(  312): Clamp target GC heap from 132.902MB to 128.000MB
D/dalvikvm(  312): GC_FOR_ALLOC freed 1852K, 4% free 126271K/130904K, paused 25ms, total 25ms
I/dalvikvm-heap(  312): Forcing collection of SoftReferences for 3134212-byte allocation
I/dalvikvm-heap(  312): Clamp target GC heap from 132.894MB to 128.000MB
D/dalvikvm(  312): GC_BEFORE_OOM freed 10K, 4% free 126261K/130904K, paused 29ms, total 29ms
E/dalvikvm-heap(  312): Out of memory on a 3134212-byte allocation.
I/dalvikvm(  312): "main" prio=5 tid=1 RUNNABLE
I/dalvikvm(  312):   | group="main" sCount=0 dsCount=0 obj=0x413eeb38 self=0x413ddd78
I/dalvikvm(  312):   | sysTid=312 nice=0 sched=0/0 cgrp=apps handle=1074968028
I/dalvikvm(  312):   | state=R schedstat=( 0 0 0 ) utm=246 stm=59 core=2
I/dalvikvm(  312):   at android.graphics.BitmapFactory.nativeDecodeAsset(Native Method)
I/dalvikvm(  312):   at android.graphics.BitmapFactory.decodeStream(BitmapFactory.java:596)
I/dalvikvm(  312):   at android.graphics.BitmapFactory.decodeResourceStream(BitmapFactory.java:444)
I/dalvikvm(  312):   at android.graphics.BitmapFactory.decodeResource(BitmapFactory.java:472)
I/dalvikvm(  312):   at guild.android.screens.CouponItemScreen.n_onTouch(Native Method)
I/dalvikvm(  312):   at guild.android.screens.CouponItemScreen.onTouch(CouponItemScreen.java:47)
I/dalvikvm(  312):   at android.view.View.dispatchTouchEvent(View.java:7495)
I/dalvikvm(  312):   at android.view.ViewGroup.dispatchTransformedTouchEvent(ViewGroup.java:2291)
I/dalvikvm(  312):   at android.view.ViewGroup.dispatchTouchEvent(ViewGroup.java:1985)
I/dalvikvm(  312):   at android.view.ViewGroup.dispatchTransformedTouchEvent(ViewGroup.java:2291)
I/dalvikvm(  312):   at android.view.ViewGroup.dispatchTouchEvent(ViewGroup.java:1985)
I/dalvikvm(  312):   at android.view.ViewGroup.dispatchTransformedTouchEvent(ViewGroup.java:2291)
I/dalvikvm(  312):   at android.view.ViewGroup.dispatchTouchEvent(ViewGroup.java:1985)
I/dalvikvm(  312):   at android.view.ViewGroup.dispatchTransformedTouchEvent(ViewGroup.java:2291)
I/dalvikvm(  312):   at android.view.ViewGroup.dispatchTouchEvent(ViewGroup.java:1985)
I/dalvikvm(  312):   at android.view.ViewGroup.dispatchTransformedTouchEvent(ViewGroup.java:2291)
I/dalvikvm(  312):   at android.view.ViewGroup.dispatchTouchEvent(ViewGroup.java:1985)
I/dalvikvm(  312):   at com.android.internal.policy.impl.PhoneWindow$DecorView.superDispatchTouchEvent(PhoneWindow.java:2240)
I/dalvikvm(  312):   at com.android.internal.policy.impl.PhoneWindow.superDispatchTouchEvent(PhoneWindow.java:1535)
I/dalvikvm(  312):   at android.app.Activity.dispatchTouchEvent(Activity.java:2466)
I/dalvikvm(  312):   at com.android.internal.policy.impl.PhoneWindow$DecorView.dispatchTouchEvent(PhoneWindow.java:2188)
I/dalvikvm(  312):   at android.view.View.dispatchPointerEvent(View.java:7689)
I/dalvikvm(  312):   at android.view.ViewRootImpl.deliverPointerEvent(ViewRootImpl.java:3794)
I/dalvikvm(  312):   at android.view.ViewRootImpl.deliverInputEvent(ViewRootImpl.java:3678)
I/dalvikvm(  312):   at android.view.ViewRootImpl.doProcessInputEvents(ViewRootImpl.java:4916)
I/dalvikvm(  312):   at android.view.ViewRootImpl.enqueueInputEvent(ViewRootImpl.java:4895)
I/dalvikvm(  312):   at android.view.ViewRootImpl$WindowInputEventReceiver.onInputEvent(ViewRootImpl.java:4993)
I/dalvikvm(  312):   at android.view.InputEventReceiver.dispatchInputEvent(InputEventReceiver.java:185)
I/dalvikvm(  312):   at android.os.MessageQueue.nativePollOnce(Native Method)
I/dalvikvm(  312):   at android.os.MessageQueue.next(MessageQueue.java:125)
I/dalvikvm(  312):   at android.os.Looper.loop(Looper.java:124)
I/dalvikvm(  312):   at android.app.ActivityThread.main(ActivityThread.java:5279)
I/dalvikvm(  312):   at java.lang.reflect.Method.invokeNative(Native Method)
I/dalvikvm(  312):   at java.lang.reflect.Method.invoke(Method.java:511)
I/dalvikvm(  312):   at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:1102)
I/dalvikvm(  312):   at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:869)
I/dalvikvm(  312):   at dalvik.system.NativeStart.main(Native Method)
I/dalvikvm(  312):
D/skia    (  312): --- allocation failed for scaled bitmap
D/dalvikvm(15696): GC_CONCURRENT freed 2085K, 39% free 14681K/23884K, paused 2ms+13ms, total 40ms

Viewing all articles
Browse latest Browse all 204402

Trending Articles



<script src="https://jsc.adskeeper.com/r/s/rssing.com.1596347.js" async> </script>