底层图像处理之微信32Kb图片压缩方案 (二)(1)

return new Size(outWidth, outHeight);

}

计算近似宽高


首先说一下为什么要有这一步:

  • 为了尽量少的占用内存,我们获取的图片只是用来在打开微信时展现一个缩略图,而实际的图片大小是无法预估的,不能盲目拿到内存中,因此我们要先计算一个大致的尺寸;

  • 最后一步中,我们将会采用循环压缩的方式逼近目标大小,先进行这步压缩,也是为了减少最后循环的次数;

这一步骤的目标就是获取到一个稍微大于 32KB 的图片,后面再进行细节微调。

那么接下来如何计算一个合适的宽高,我们简单的这样约束 32kb = w * h,虽然这样并不完全合理,因为最终 byte[] 的长度和宽高并没有绝对的关系,不过之前也说过了,这步是不精确的,目标是一个大于稍微 32KBbitmap;

于是可以得到如下关系,为了好理解,就用汉字标识:

比例(>1) = 较长边 / 较短边

32KB = 较短边 * 较长边

32KB = 较短边 * 较短边 * 比例(>1)

较短边 = sqrt(maxSize/比例(>1))

较长边 = 较短边 * 比例(>1)

经过上面的关系,可以按照比例计算出 较短边较长边,代码如下,简单看下:

/**

  • 根据kb计算缩放后的大约宽高

  • @param originSize 图片原始宽高

  • @param maxSize byte length

  • @return 大小

*/

private static Size calculateSize(Size originSize, int maxSize) {

int bw = originSize.width;

int bh = originSize.height;

Size size = new Size();

// 如果本身已经小于,就直接返回

if (bw * bh <= maxSize) {

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值