业余版概要:

安卓的一个核心的部分的代码,为了优化执行速度进行了魔改,结果写错了代码。结果导致 JPG 图片压缩发绿、崩坏。与安卓上的应用无关,它们是受害者

专业版概要:

问题出在 Android 提供的压缩图片接口上,准确的说是一个 Android 里一个叫做 Skia 的库上。而这个 bug 在 2016 年 4 月中旬被修复了,如果按照 Android 的发行来看,那就是从 Android 7 (Nougat) 开始才消除这个问题。

问题出在 RGB 色彩空间转换到 YUV 的时候。但问题不仅仅是精度下降,最大的问题是,错误的舍入(向下取整)。

现在就要说到 Android 系统到底为什么出了这个问题了。Android 系统自起诞生以来就引入了名为 Skia 的图像库(Google 自家产品),用于处理图像,其中包括把图片压缩成 JPEG(平时说的 JPG)。而 Skia 又是调用libjpeg-turbo 来实现真正的压缩过程的。为了达到更好的压缩效果,JPEG 算法本身,将通常屏幕上表示颜色的 RGB(红绿蓝)数值,转换为 YUV 数值(亮度,蓝色分量,红色分量)。正常情况下这个算法是轻微有损的。

但是 Skia 不走寻常路,在将这个变换算法的各个常数复制到自己的代码里的时候(当然是合法地),降低了精度,以达到更高的速度(专业准确地说,从 16 位定点数,降低到了 8 位定点数),这导致了更大的损伤。

最可怕的是……在进行这个变换运算的最后一步,需要除以 256,而代码中,采用了右移操作代替除法以提高执行速度。

假如我们是 Skia 开发者,如何修复这个问题?

交回给 libjpeg-turbo 库自己来做色彩空间变换,把原本 Skia 库 YUV 转换代码全部删掉了,把这个过程留给整个过程最底层的 libjpeg-turbo库自己来做,并且用默认的 JDCT_ISLOW 方法代替JDCT_IFAST 方法。

总结

以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作具有一定的参考学习价值,谢谢大家对脚本之家的支持。如果你想了解更多相关内容请查看下面相关链接

更多相关文章

  1. Android通过代码打开和关闭网络连接
  2. Android(安卓)文件选择器详解及实例代码
  3. Android(安卓)UI控件学习(一)——拖动条
  4. Android之反编译技术
  5. Fatal signal 11 (SIGSEGV), code 1, fault addr 0x34 in tid 75
  6. 如何将Android数据库操作通用化(一)
  7. [程序猿感悟] Android平台开发中的重构三步走
  8. Android中微信支付的调用方法
  9. Android(安卓)Studio 设置代码提示和代码自动补全快捷键--Eclips

随机推荐

  1. 11.11flex布局导航
  2. 简单了解composer及MVC
  3. HTML标签作业之table-lesson02
  4. 带有二级分类的导航
  5. 弹性布局和下拉列表
  6. 纯静态文件打包部署预览链接,来自于vue的c
  7. 表格与表单
  8. 导航制作flex
  9. 带二级分类的导航
  10. 前端基础,伸缩盒布局小案例及总结