聊聊图片压缩的优化

简介: 聊聊图片压缩的优化

本篇文章主要是聊聊压缩的优化,尽量不贴代码,文章结构也尽量保证短小。

比例压缩


比例压缩是一种非常常见的算法,主要是通过设置


BitmapFactory.Options.inSampleSize 来压缩,我们可以自己设置压缩的比例,也可以根据目标控件的宽、高度来等比设置比例,压缩效率一般,所以我们时常会配合质量压缩一块来压缩。

质量压缩


拿到等比压缩过后的图片,我们可以通过 bitmap.compress(Bitmap.CompressFormat.JPEG, quality, baos) 来实现质量压缩,我们主要关注以下俩个参数:


1、CompressFormat  是我们要压缩的格式,包含的格式有:

  • JPEG:压缩为 JPEG 格式,压缩质量随 quality 改变,一般都用它
  • PNG:压缩为 PNG 格式,PNG 是无损的,他会忽略 quality 值,一般不用
  • WEBP:压缩为 WEBP 格式,压缩质量随 quality 改变,但从 Android Q 开始,quality=100 时,将会采用无损压缩,一般不用

2、quality 是我们要压缩的质量,压缩区间为 0 ~ 100,一般我们会设置压缩质量为 80.

色值压缩


色值压缩通过 BitmapFactory.OptionsinPreferredConfig 来设置,对应的 config 有:


  • ALPHA_8
  • RGB_565
  • ARGB_4444
  • ARGB_8888
  • RGBA_F16
  • HARDWARE


这几种配置都是通过设置单个像素点的位数来改变图片大小,比如 ARGB_8888 和 RGB_565,前者采用 4*8 = 32 位来表示一个像素,后者采用 5+6+5 = 16 位来表示一个像素,在质量大小上面,RGB_565 比 ARGB_8888 小了 1 倍。

算法压缩


前面讲了这么多,都逃脱不了压缩的界定值问题,就是到底设置什么样的值,既能保证图片清晰,还能保证大小压缩已经到了极致。这个地方又要引入一个第三方框架,那就是 Luban,Luban 的精华部分就是实现了一套 inSampleSize 的算法计算,保证图片的压缩是极致的,具体代码可以查看 computeSize 方法,这里就不贴代码了。

Native 压缩



虽然 Luban 将压缩发挥了极致,但毕竟只是计算 inSampleSize,相比较 native 的 libjpeg 而言,压缩又进了一个等级。关于 libjpeg 的 分析可以看我这篇文章《JNI 之 Libjpeg 分析》,Luban 的作者也做了一个基于 libjpeg 的库—— Luban-Turbo

问题


上面的所有算法,都有一个致命问题 —— 压缩前需要加载进内存。对于大图而言,100M 的图片加载进内存会导致内存拼命增长,发生 OOM 会导致应用进程崩溃。

方案


压缩前需要加载进内存这个貌似无法解决,但我们可以另辟新径,开个新的进程出来,专门来处理图片压缩,即使加载进的图片非常大导致进程崩溃,也不会影响到主进程。

对于开个新进程来处理图片压缩问题,我想到的一个比较简单的方案是创建一个专门处理压缩的 Activity,并设置 process 为单独的一个进程:


<activity
      android:name=".ProcessActivity"
      android:process=":compress"/>
复制代码


如果体验想更佳的话,我们可以给 activity 设置 dialog theme,然后布局设置为一个 loading 加载框等待压缩,压缩完成后,setResult 将压缩结果带回:


image.png


目录
相关文章
|
7月前
|
前端开发 算法 JavaScript
如何优化前端性能:探索图片压缩与延迟加载技术
本文深入探讨了前端性能优化中的关键问题:图片压缩与延迟加载技术。通过介绍图片压缩的原理和方法,并结合实例说明了如何有效减少图片大小、提升加载速度;同时,详细解析了延迟加载技术的实现原理及其在提高页面加载性能中的作用,为前端开发者提供了实用的优化方案。
|
前端开发 JavaScript C++
前端优化指南:我们该怎么去压缩图像?
前端优化指南:我们该怎么去压缩图像?
241 0
图片压缩后,依然很大的解决方案
图片压缩后,依然很大的解决方案
117 0
|
存储 编解码 Android开发
一款压缩图片又不损画质的黑科技软件!!!
一款压缩图片又不损画质的黑科技软件!!!
|
存储 前端开发 算法
前端性能优化-图片
前端性能优化-图片
266 29
前端性能优化-图片
|
存储 缓存 前端开发
浅谈性能优化之图片压缩、加载和格式选择
目前市场上优化图片资源的方式有很多,如压缩图片、选择正确格式、 CDN 加速、懒加载等。
275 0
浅谈性能优化之图片压缩、加载和格式选择
|
存储 Web App开发 编解码
前端性能优化系列 | 图像优化(下)
图片在各大网站随处可见,因为图片的表述比文字更加直观,所以图片是网站最重要的要素之一。图片相对其他文件又很大,页面的加载速度很大程度上取决于图片的加载速度,所以我们要对图片进行优化,以此加快页面加载速度,提升用户体验。 图片的优化可以分为两个方面:图像的选取和使用,加载和显示。本文主要讨论从图片的选取和使用来进行性能的优化,下一篇文章来介绍图片的加载优化。
288 0
|
机器学习/深度学习 人工智能 编解码
画质不变,体积却缩减 75%,谷歌这项图片压缩黑科技也是牛了!
去年年中的时候网络上曾流传一个消息称谷歌正在开发一种新技术,利用人工智能技术压塑图片,可以使图片在画质不变的情况下缩减文件体积,半年过去,这种技术已经研发成功。 日前,谷歌推出了一项名为-RASIR 的图像压缩技术,官方介绍表示,其能使图片画质保持不变的情况下将文件体积缩减 75%。
299 0
画质不变,体积却缩减 75%,谷歌这项图片压缩黑科技也是牛了!
|
JavaScript 前端开发
ImagesQuicklyCompress-图片压缩插件
一款针对javascript开发的图片压缩插件
214 0
|
前端开发 算法 索引
前端性能优化-图像优化
前端性能优化-图像优化
119 0