本文讲的是Facebook iOS 应用是如何加速图片显示的?,

你的Facebook的动态消息中充满着一些关于你朋友、家人以及你所爱的人的照片,也许你会想要在手机上也能重温那些场景。我们一直在寻找提升用户体验的方式,包括更优秀和更快的移动端体验。为了达到这个目标,我们团队仔细研究了如何在 iOS 设备上更好更快得显示照片并最终找到了一种方法,能够让 Facebook for iOS 的数据开销降低10%,同时将照片加载显示的速度提升了15%。接下来的内容是讲述我们如何做到这一点的。

过去图片是如何被处理的

到目前为止, Facebook for iOS 是根据如下步骤加载你动态消息中照片:

  • 我们先拿到这个图片的所有链接,然后根据这个链接来下载格式为JPEG的照片数据。
  • 至少两个版本的图片被同时请求,这包括一张缩略图和一张全尺寸的图片。一旦小的缩略图下载好之后,我们会先显示小的缩略图直到更高精度的图片能被用于展示。
  • 有时候,我们会根据不同的尺寸将同一张图片下载多次。具体的尺寸是根据设备的型号以及图片在 app 中出现的场景来定义(比如在动态消息当中或者是全屏的 photo viewer )
  • 因为我们对于同一个图片下载了多个尺寸的版本,所以这些不同尺寸的图片都会被储存在设备的闪存中

渐进式图片

渐进式图片 Progressive JEPG(简称为 PJEPG )是一种储存多个独立“扫描”的图片格式。并且图片的精度会随着扫描的次数增加,变的越来越清晰。当所有的扫描版本叠加之后,一张最高精度的图片就会被显示出来。第一次的扫描能给予用户第一个低质量的缩略图。之后的每一层扫描都会使得这张图片的精度上升一个等级。当图片以PJPEG的格式被下载的时候,一旦第一层扫描结束我们可以马上在手机上为用户显示缩略图。当之后的扫描被下载后,我们会更新图片到一个更好的质量。

浏览器对于PJEPG格式图片的支持在2010的时候就已经非常流行了。并且我们采用PJEPG作为图片格式已经有一段时间了。然而,手机端的应用们似乎还没赶上这个潮流。举个例子, iOS 端上还没有渐进式处理图片的支持,所以我们不得不为在 iOS 上的 Facebook 开发新的方式来做到这一点。

在 Facebook 的 iOS 客户端上用渐进式图片

在 Facebook for iOS 中采用渐进式的图片渲染有如下一些好处:

  1. 数据消耗:PJPEG使得我们可以避免下载小尺寸的图片。
  2. 网络连接:因为我们不再需要下载缩略图,我们现在每张图片只需要用到一个数据连接来代替过去使用多个数据连接来下载同一张图片。
  3. 硬盘储存:使用PJPEG来储存图片减少了应用对于硬盘的占用。
  4. 一个URL:因为我们不再需要根据不同的尺寸来多次下载图片,所以我们可以用相同的URL标识资源。

然而使用 PJPEG 的图片有一个缺点:下载并渲染多个扫描层会占用更多 CPU 的资源。即使解码这些图片可以在后台处理,但是这个进程对于 CPU 来说还是非常繁重。对于我们来说,问题在于在数据占用,网络延迟和CPU的利用率上找到一个平衡点。比如说我们曾经考虑使用WebP 从文件大小的角度来说,WebP和JPEG相比,在某些情况下是更优的。但这种格式不支持渐进式的渲染。

等待图片加载

下面这张图片很好的解释了我们在 iOS 端的 Facebook 上是如何下载图片的。下面的两张图片都表示下载一张图片的情况。 “Wait Time” 表示了从显示一张图片的占位符到加载出清晰能让人表示满意的图片所需要的时间。即使当缩略图片已经显示了,许多用户还是不愿再等待全图的加载。 

当我们使用PJPEG的图片的时候: 

对于每一张图片,我们在三个不同的扫描层次上进行渲染。

  1. 首先,我们渲染一张能够满足预览效果的图片,这一步是像素化的过程。
  2. 然后,我们渲染出一张肉眼看上去还不错的图片。事实上,它看上去几乎就是完美的。
  3. 最后我们渲染出一张最高质量的图片:达到最高分辨率的一张图。

结果就是用户们可以更快的看到一张棒棒的图片!

如何找到正确的扫描分层程度

为了知道什么叫做一张令人满意的图片,我们尝试了不同的扫描层级,并最终找到了人们操作图片时涉及最多的那几个层级。我们同时也研究了不同扫描层级的图片与最终完整图片之间的相似度。我们的对比功能会获取两张图片并返还一个0到1之间的数字来表示他们的相似度。0是完全不像,1是完全一样。下面是一些测试的结果:

为了对比选择不同扫描分层深度所带来的影响,我们还做了个A/B 测试 然后对数据进行了核实。

取得的成果

  1. 在 iOS 端上的 Facebook 采用PJPEG后数据占用减少了10%。
  2. 在用了用PJPEG之后,我们将加载一张令用户满意的图片的速度提高了15%左右。新的图片和原来的全精度图片相比几乎没有区别。
  3. 采用PJEPG帮助我们提高了预览图的加载速度。通过这种方式,虽然 CPU 比以前多用了一点资源,但是我们大大减少了需要下载一张图片的时间。

在 Facebook ,我们仍然继续致力于减少用户等待的时间,并且这只是我们很多努力中的一小部分。即使采用PJPEG后,照片的加载速度已经变得很快了,但是我们知道还是有很多提升的空间来更好的提升用户体验。

很多人都在这个项目上花费了相当的时间;我们应当感谢Linji Yang, Miguel Cohnen, Kun Chen, Kirill Pugin, Edward Kandrot, Marty Greenia, Brian Cabral 和 Tomer Bar.





原文发布时间为:2016年04月20日

本文来自云栖社区合作伙伴掘金,了解相关信息可以关注掘金网站。

Facebook iOS 应用是如何加速图片显示的?相关推荐

  1. IOS疯狂基础之GIF图片的显示

    2019独角兽企业重金招聘Python工程师标准>>> IOS疯狂基础之GIF图片的显示 iPhone SDK提供了多种动画手段,UIView.UIImageView和CALayer ...

  2. [emWin]利用内存设备加速GIF图片显示——2021.03

    本文为作者原创,如需转载请在醒目位置标明原始出处,并提供可访问的超链接. 效果 实现原理 emWin的GIF显示原理是用户程序调用GUI_GIF_DrawSub()绘制函数一帧一帧的解码和显示,并且每 ...

  3. 关于IOS中uni.downloadFile下载的图片显示不出来的解决方法

    1.如果你遇到的下载后的返回路径是如下情况的 2.此时IOS有可能会出现图片显示不出来(我自己手机测试是显示不出来) 3.针对此情况,我们可以在IOS端下进行单独处理,使用escape escape( ...

  4. [emWin]利用内存设备加速PNG图片显示——2021.03

    本文为作者原创,如需转载请在醒目位置标明原始出处,并提供可访问的超链接. 上一篇博客中讲了[emWin]利用内存设备加速GIF图片显示,那么这一篇来讲一下同样的方法加速PNG图. 实现原理 emWin ...

  5. ios 中webView加载html文本图片显示不全

    在iOS开发过程中,用webView显示富文本内容是很常见的需求,加载富文本时通常还要根据webView的高度动态计算cell的高度(例如我们要在tableView或者collectionView的某 ...

  6. 如何在python中显示电脑中的图片-python如何实现多个图片显示在屏幕上?

    pygame的三个方法(屏幕上显示需要的图片) yuhu102319582018-12-16 python将多幅图片显示在一张图片上 wugui1111116282018-06-15 iOS 图片显示 ...

  7. 服务器上有图片但是app不显示不出来,网络app图片显示不出来的

    网络app图片显示不出来的 内容精选 换一换 接入CDN加速后,用户访问网站或者APP资源依然很慢.域名是否接入CDN加速是否命中CDN缓存是否跨运营商和跨省缓存规则设置是否合理加速资源是否预热是否客 ...

  8. ios项目icon和default图片命名规则

    一.应用图片 标准iOS控件里的图片资源,苹果已经做了相应的升级,我们需要操心的是应用自己的图片资源.就像当初为了支持iPhone 4而制作的@2x高分辨率版本(译者:以下简称高分)图片一样,我们要为 ...

  9. 如何提高网页中图片显示的用户体验(附源码下载)

    文章中加入适量的图片不仅可以更好的说明和补充文章的内容,而且还可以极大的减缓阅读者在阅读较长篇幅文章时的疲劳和不安.所以图文混排较好的文章能给阅读者更好的用户体验和享受.但是令人遗憾的是很多的网页图片 ...

最新文章

  1. 递归/回溯:Combination Sum II数组之和
  2. 可怕!如果张东升是个程序员......
  3. C语言 游戏远程call调用,C++远程调用类操作支持CallbackInterface(1)
  4. Nuget打包类库及引用
  5. @即将开学的你,请收好这份必读论文清单
  6. Python之深入解析如何制作国际空间站实时跟踪器
  7. 1. VIM 系列 - 简单入门,拾起兴趣
  8. 【myeclipse】java.lang.NullPointerException at com.genuitec.eclipse.ast.deploy.core.Deployment
  9. 洛谷OJ上的A+B花(zhuang)式(bi)解法
  10. OpenSSF 获1000万美元投资,提升开源软件和软件供应链安全
  11. Can‘t exec “autopoint“: 没有那个文件或目录 at /usr/share/autoconf/Autom4te/FileUtils.pm line 345.
  12. 左耳朵耗子:如何超过大多数人
  13. tomcat日志配置(停止日志或修改日志路径)
  14. java mp3转g722_(转载)wav文件转成g722, g729编码的文件
  15. 七夕表白之Python画玫瑰花
  16. html5 微信签到墙,3D签到墙 webgl示例源码(three.js)
  17. 多线程中的公平锁和非公平锁
  18. ML - 贷款用户逾期情况分析5 - 特征工程2(特征选择)
  19. 磁粉制动器磁滞特性的研究笔记
  20. 浏览器HTTP_USER_AGENT汇总——Firefox、Chrome、IE9、IE8、IE7、IE6

热门文章

  1. 人均月薪 7.5 万,腾讯 Q2 成绩单来了,网友酸了?
  2. TCP/IPICMP报文的分类
  3. ExtJS 4.2 教程-08:布局系统详解
  4. AI2XAML's Bug(sequel)
  5. 【机器学习】--隐含马尔科夫模型从初识到应用
  6. vim编辑器操作命令大全-绝对全
  7. TRUNC函数,ORA-01898 精度说明符过多
  8. 从今天开始,我就要潜心研究软件开发技术了,不在被名利所困
  9. 腾讯是一只邪恶的小企鹅
  10. 还有人不懂分布式锁的实现就把这篇文章丢给他