目录
data:image/s3,"s3://crabby-images/4e449/4e4490d5f9115609278c94d4db26a60f1670f17e" alt=""
Bitmap优化
1.Bitmap.Config配置
这里我们用BitmapFactory.decodeResource不加BitmapFactory.Options的方式来加载Bitmap
Bitmap bitmap = BitmapFactory.decodeResource(getResources(), R.drawable.ic_bg);
img.setImageBitmap(bitmap);
这时我们可以查看APP消耗的内存
data:image/s3,"s3://crabby-images/a6270/a6270a9213c3d91c1d2f52c43568687fc4eb16b6" alt=""
然后我们加上BitmapFactory.Options设置Bitmap.Config为RGB_565,这时我们再看APP的运行内存
data:image/s3,"s3://crabby-images/c0219/c0219fbea3071e1d43636d7b55e0ef7d7ba8459f" alt=""
我们可以发现内存使用少了10MB多,这是因为默认Bitmap的Config为ARGB_8888,需要占的空间比较多,而我们如果对图片的显示要求不是很大的话,我们就可以通过配置Bitmap.Config减少内存的使用
2.加载方式优化
BitmapFactory.decodeResource与BitmapFactory.decodeStream相比
● BitmapFactory.decodeResource
//记录开始加载时的时间
long startTime = System.currentTimeMillis();
Bitmap bitmap = BitmapFactory.decodeResource(getResources(), R.raw.ic_bg);
img.setImageBitmap(bitmap);
//计算加载的耗时
long useTime = System.currentTimeMillis() - startTime;
Log.e("加载时间",useTime + "ms");
我们用一张168kb的图片加载发现所用时间为212ms
data:image/s3,"s3://crabby-images/f5d6e/f5d6eb4be7bf7223a0d45c355bdab045ee5581b7" alt=""
● BitmapFactory.decodeStream
//记录开始加载时的时间
long startTime = System.currentTimeMillis();
InputStream inputStream = getResources().openRawResource(R.raw.ic_bg);
Bitmap bitmap = BitmapFactory.decodeStream(inputStream);
img.setImageBitmap(bitmap);
//计算加载的耗时
long useTime = System.currentTimeMillis() - startTime;
Log.e("加载时间",useTime + "ms");
我们发现同样的图片仅用24ms
data:image/s3,"s3://crabby-images/0c8cc/0c8cc5a3025b2ec64771b104029775bf67afb006" alt=""
而且消耗的内存也很小
data:image/s3,"s3://crabby-images/0f6f9/0f6f9fe2ec4fc166b5bf54a55e894eb28efaca14" alt=""
网友评论