今天做项目,发现需要显示一张超大图片,处理过后,还有561Kb
加载的时候,就crash --- OOM
shortMsg:java.lang.OutOfMemoryError
longMsg:java.lang.OutOfMemoryError: bitmap size exceeds VM budget
stackTrace:java.lang.OutOfMemoryError: bitmap size exceeds VM budget
at android.graphics.Bitmap.nativeCreate(Native Method)
at android.graphics.Bitmap.createBitmap(Bitmap.java:477)
at android.graphics.Bitmap.createBitmap(Bitmap.java:444)
at android.graphics.Bitmap.createScaledBitmap(Bitmap.java:349)
at android.graphics.BitmapFactory.finishDecode(BitmapFactory.java:512)
at android.graphics.BitmapFactory.decodeStream(BitmapFactory.java:487)
at android.graphics.BitmapFactory.decodeResourceStream(BitmapFactory.java:336)
代码如下:
detailView=(ImageView)findViewById(R.id.detailView);
detailView.setBackgroundResource(R.drawable.more_info);//this line will lead to OOM
换成这种:
detailView.setImageResource(R.drawable.more_info); //也同样会OOM
后来找到了solution:
/**
* 以最省内存的方式读取本地资源的图片
* @param context
*@param resId
* @return
*/
public static Bitmap readBitMap(Context context, int resId){
BitmapFactory.Options opt = new BitmapFactory.Options();
opt.inPreferredConfig = Bitmap.Config.RGB_565;
opt.inPurgeable = true;
opt.inInputShareable = true;
//获取资源图片
InputStream is = context.getResources().openRawResource(resId);
return BitmapFactory.decodeStream(is,null,opt);
}
取得bitmap之后,再 detailView.setImageBitmap(pdfImage); 就ok了!
那是为什么,会导致oom呢:
原来当使用像 imageView.setBackgroundResource,imageView.setImageResource, 或者 BitmapFactory.decodeResource 这样的方法来设置一张大图片的时候,
这些函数在完成decode后,最终都是通过java层的createBitmap来完成的,需要消耗更多内存。
因此,改用先通过BitmapFactory.decodeStream方法,创建出一个bitmap,再将其设为ImageView的 source,decodeStream最大的秘密在于其直接调用JNI>>nativeDecodeAsset()来完成decode,无需再使用java层的createBitmap,从而节省了java层的空间。如果在读取时加上图片的Config参数,可以跟有效减少加载的内存,从而跟有效阻止抛out of Memory异常。
另外,需要特别注意:
decodeStream是直接读取图片资料的字节码了, 不会根据机器的各种分辨率来自动适应,使用了decodeStream之后,需要在hdpi和mdpi,ldpi中配置相应的图片资源,否则在不同分辨率机器上都是同样大小(像素点数量),显示出来的大小就不对了。
原文引用:http://blog.csdn.net/woshicaixianfeng/article/details/6825295
分享到:
相关推荐
android加载大图避免oom,博客http://blog.csdn.net/u012305710/article/details/51079676
Android高级应用源码-加载本地图片,绝对不会出现OOM.zip
Android解决图片加载OOM与listview图片错位乱跳问题解决,开源的代码,里面有示例demo
android gridview 加载大量图片。无OOM。 程序运行默认加载SD卡内所有图片文件,这是我写了之后用在一款成熟app里面的。可用
安卓下显示图片经常遇到OOM问题,这里给出了常用解决方案
解决Android加载图片出现的OOM问题
加载本地图片,绝对不会出现OOM
有效控制了Android大图片、多图片加载的OOM异常。
Android 异步加载图片缓存优化能异步加载图片,并缓存到本地,采用一级缓存,二级缓存和本地缓存,避免oom异常。源码中有详细注释,资料中有jar包,可以直接复制到项目中使用。
安卓在加载大图的时候经常会出现oom的错误,给大家分享我的一些处理经验。
android 图片加载优化 解决的OOM异常
甚至还可以从各种各样奇葩的数据源中加载图片。 加载网络图片 很多情况下,我们使用图片加载库就是为了加载网络图片。网络操作是一个很复杂的东西。试想一下,如果没有图片加载库,我们就要手动去下载图片,缓存图片...
加载大图片到内存时如何防止 OOM的产生
android端用于异步加载图片,内存缓存,文件缓存,imageview显示图片时增加淡入淡出动画。.zip Android高级图片滚动控件,3D版的图片轮播器Demo.rar GiF完美运行!!!!.rar ViewFlowTest 完美实现gallry轮训效果!...
android加载大量图片内存溢出的三种解决办法
Android-Universal-Image-Loader-master 很好用的多图片加载 也可以自己修改成单图片的 simple是例子 包括List Grid 以及类似qq多图片滑动的
安卓Android源码——加载本地图片,绝对不会出现OOM.zip
安卓Android源码——加载本地图片,绝对不会出现OOM.rar
从项目拷出来的源码,解决ViewFlipper加载多张图片出现OOM问题,测试加载20张图片无异常,有需要的同学可以下载看看,需自己修改下代码