In the process of tracking severe memory issues in my app, I looked at several heap dumps from my app, and most of the time I have a HUGE bitmap that I don’t know of.
It takes 9.4MB, or 9,830,400 bytes, or actually a 1280×1920 image at 4 bytes per pixels.
I checked in Eclipse MAT, it is indeed a byte[9830400], that has one incoming reference which is a android.graphics.Bitmap.
I’d like to dump this to a file and try to see it. I can’t understand where is it coming from. My biggest image in all my drawables is a 640×960 png, which takes less than 3MB.
I tried to use Eclipse to “copy value to file”, but I think it simply prints the buffer to the file, and I don’t know any image software that can read a stream of bytes and display it as a 4 bytes per pixel image.
Any idea?
Here’s what I tried: dump the byte array to a file, push it to /sdcard/img, and load an activity like this:
@Override
public void onCreate(final Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
try {
final File inputFile = new File("/sdcard/img");
final FileInputStream isr = new FileInputStream(inputFile);
final Bitmap bmp = BitmapFactory.decodeStream(isr);
ImageView iv = new ImageView(this);
iv.setImageBitmap(bmp);
setContentView(iv);
Log.d("ImageTest", "Image was inflated");
} catch (final FileNotFoundException e) {
Log.d("ImageTest", "Image was not inflated");
}
}
I didn’t see anything.
Do you know how is encoded the image? Say it is stored into byte[] buffer. buffer[0] is red, buffer[1] is green, etc?
OK — After quite some unsuccessful tries, I finally got something out of this byte array. I wrote this simple C program to convert the byte array to a Windows Bitmap file. I’m dropping the code in case somebody is interested.
I compiled this against VisualC 6.0 and gcc 3.4.4, it should work on any OS (tested on Windows, Linux and MacOS X).
So using this tool I was able to recognise the picture used to generate this 1280×1920 bitmap.