I am getting OutOfMemoryError on BitMap while calling Bitmap.createScaledBitmap
I already tried to recycle and setting to null to the BitMap reference, but still stucked.
Code which I am using is
private Bitmap getImageBitmap(float startX, float startY, float currX, float currY, Resources res, int resId) {
Bitmap bitSrc = BitmapFactory.decodeResource(res, resId);
int dstWidth = (int) ((Math.abs((currX - startX)) + 1));
int dstHeight = (int) ((Math.abs((currY - startY)) + 1));
Bitmap bitImg = Bitmap.createScaledBitmap(bitSrc, dstWidth, dstHeight, false);
bitSrc = null;
return bitImg;
}
I am setting the returned bitImg on canvas. Here is my Log file
08-14 13:31:14.364: E/AndroidRuntime(6714): java.lang.OutOfMemoryError
08-14 13:31:14.364: E/AndroidRuntime(6714): at android.graphics.Bitmap.nativeCreate(Native Method)
08-14 13:31:14.364: E/AndroidRuntime(6714): at android.graphics.Bitmap.createBitmap(Bitmap.java:809)
08-14 13:31:14.364: E/AndroidRuntime(6714): at android.graphics.Bitmap.createBitmap(Bitmap.java:786)
08-14 13:31:14.364: E/AndroidRuntime(6714): at android.graphics.Bitmap.createBitmap(Bitmap.java:718)
08-14 13:31:14.364: E/AndroidRuntime(6714): at android.graphics.Bitmap.createScaledBitmap(Bitmap.java:594)
08-14 13:31:14.364: E/AndroidRuntime(6714): at com.example.layout.Drawing.getImageBitmap(DrawingSurface.java:856)
08-14 13:31:14.364: E/AndroidRuntime(6714): at com.example.layout.Drawing.onDraw(DrawingSurface.java:291)
08-14 13:31:14.364: E/AndroidRuntime(6714): at android.view.View.draw(View.java:14465)
08-14 13:31:14.364: E/AndroidRuntime(6714): at android.view.View.getDisplayList(View.java:13362)
08-14 13:31:14.364: E/AndroidRuntime(6714): at android.view.View.getDisplayList(View.java:13404)
08-14 13:31:14.364: E/AndroidRuntime(6714): at android.view.ViewGroup.dispatchGetDisplayList(ViewGroup.java:3077)
08-14 13:31:14.364: E/AndroidRuntime(6714): at android.view.View.getDisplayList(View.java:13300)
08-14 13:31:14.364: E/AndroidRuntime(6714): at android.view.View.getDisplayList(View.java:13404)
08-14 13:31:14.364: E/AndroidRuntime(6714): at android.view.ViewGroup.dispatchGetDisplayList(ViewGroup.java:3077)
08-14 13:31:14.364: E/AndroidRuntime(6714): at android.view.View.getDisplayList(View.java:13300)
08-14 13:31:14.364: E/AndroidRuntime(6714): at android.view.View.getDisplayList(View.java:13404)
08-14 13:31:14.364: E/AndroidRuntime(6714): at android.view.ViewGroup.dispatchGetDisplayList(ViewGroup.java:3077)
08-14 13:31:14.364: E/AndroidRuntime(6714): at android.view.View.getDisplayList(View.java:13300)
08-14 13:31:14.364: E/AndroidRuntime(6714): at android.view.View.getDisplayList(View.java:13404)
08-14 13:31:14.364: E/AndroidRuntime(6714): at android.view.ViewGroup.dispatchGetDisplayList(ViewGroup.java:3077)
08-14 13:31:14.364: E/AndroidRuntime(6714): at android.view.View.getDisplayList(View.java:13300)
08-14 13:31:14.364: E/AndroidRuntime(6714): at android.view.View.getDisplayList(View.java:13404)
08-14 13:31:14.364: E/AndroidRuntime(6714): at android.view.ViewGroup.dispatchGetDisplayList(ViewGroup.java:3077)
08-14 13:31:14.364: E/AndroidRuntime(6714): at android.view.View.getDisplayList(View.java:13300)
08-14 13:31:14.364: E/AndroidRuntime(6714): at android.view.View.getDisplayList(View.java:13404)
08-14 13:31:14.364: E/AndroidRuntime(6714): at android.view.HardwareRenderer$GlRenderer.buildDisplayList(HardwareRenderer.java:1626)
08-14 13:31:14.364: E/AndroidRuntime(6714): at android.view.HardwareRenderer$GlRenderer.draw(HardwareRenderer.java:1505)
08-14 13:31:14.364: E/AndroidRuntime(6714): at android.view.ViewRootImpl.draw(ViewRootImpl.java:2460)
08-14 13:31:14.364: E/AndroidRuntime(6714): at android.view.ViewRootImpl.performDraw(ViewRootImpl.java:2332)
08-14 13:31:14.364: E/AndroidRuntime(6714): at android.view.ViewRootImpl.performTraversals(ViewRootImpl.java:1962)
08-14 13:31:14.364: E/AndroidRuntime(6714): at android.view.ViewRootImpl.doTraversal(ViewRootImpl.java:1079)
08-14 13:31:14.364: E/AndroidRuntime(6714): at android.view.ViewRootImpl$TraversalRunnable.run(ViewRootImpl.java:5784)
08-14 13:31:14.364: E/AndroidRuntime(6714): at android.view.Choreographer$CallbackRecord.run(Choreographer.java:774)
08-14 13:31:14.364: E/AndroidRuntime(6714): at android.view.Choreographer.doCallbacks(Choreographer.java:587)
08-14 13:31:14.364: E/AndroidRuntime(6714): at android.view.Choreographer.doFrame(Choreographer.java:550)
08-14 13:31:14.364: E/AndroidRuntime(6714): at android.view.Choreographer$FrameDisplayEventReceiver.run(Choreographer.java:760)
08-14 13:31:14.364: E/AndroidRuntime(6714): at android.os.Handler.handleCallback(Handler.java:733)
08-14 13:31:14.364: E/AndroidRuntime(6714): at android.os.Handler.dispatchMessage(Handler.java:95)
08-14 13:31:14.364: E/AndroidRuntime(6714): at android.os.Looper.loop(Looper.java:136)
08-14 13:31:14.364: E/AndroidRuntime(6714): at android.app.ActivityThread.main(ActivityThread.java:5017)
08-14 13:31:14.364: E/AndroidRuntime(6714): at java.lang.reflect.Method.invokeNative(Native Method)
08-14 13:31:14.364: E/AndroidRuntime(6714): at java.lang.reflect.Method.invoke(Method.java:515)
08-14 13:31:14.364: E/AndroidRuntime(6714): at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:785)
08-14 13:31:14.364: E/AndroidRuntime(6714): at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:601)
08-14 13:31:14.364: E/AndroidRuntime(6714): at dalvik.system.NativeStart.main(Native Method)
Thanks in advance.