对已经载入内存的图片做压缩以后重新保存到本地,从而可以把一张原本1M大小的图片变成一张10K的图片。
这种方法的核心思想是首先将图片转成一个输出流,并记录输出流的byte数组大小,通过调用bitmap对象的compress方法,对图片做一次压缩以及格式化,并将byte数组大小与期望压缩的目标大小比对,得出压缩比率,并调用Bitmap的缩放方法,缩放计算出的压缩比率,从而得到压缩后的方法。
/**
* 图片压缩方法:(使用compress的方法)
*
* @explain 如果bitmap本身的大小小于maxSize,则不作处理
* @param bitmap
* 要压缩的图片
* @param maxSize
* 压缩后的大小,单位kb
*/
public static void imageZoom(Bitmap bitmap, double maxSize) {
// 将bitmap放至数组中,意在获得bitmap的大小(与实际读取的原文件要大)
ByteArrayOutputStream baos = new ByteArrayOutputStream(); // 格式、质量、输出流
bitmap.compress(Bitmap.CompressFormat.JPEG, 100, baos);
byte[] b = baos.toByteArray(); // 将字节换成KB
double mid = b.length / 1024; // 获取bitmap大小 是允许最大大小的多少倍
double i = mid / maxSize; // 判断bitmap占用空间是否大于允许最大空间 如果大于则压缩 小于则不压缩
if (i > 1) { // 缩放图片 此处用到平方根 将宽带和高度压缩掉对应的平方根倍 //
// (保持宽高不变,缩放后也达到了最大占用空间的大小)
bitmap = scale(bitmap, bitmap.getWidth() / Math.sqrt(i),
bitmap.getHeight() / Math.sqrt(i));
}
}
/***
* 图片的缩放方法
*
* @param src
* :源图片资源
* @param newWidth
* :缩放后宽度
* @param newHeight
* :缩放后高度
*/
public static Bitmap scale(Bitmap src, double newWidth, double newHeight) { // 记录src的宽高
float width = src.getWidth();
float height = src.getHeight(); // 创建一个matrix容器
Matrix matrix = new Matrix(); // 计算缩放比例
float scaleWidth = ((float) newWidth) / width;
float scaleHeight = ((float) newHeight) / height; // 开始缩放
matrix.postScale(scaleWidth, scaleHeight); // 创建缩放后的图片
return Bitmap.createBitmap(src, 0, 0, (int) width, (int) height,
matrix, true);
}