写点什么

图片即时优化的三种简单解决方案

  • 2017-09-20
  • 本文字数:5788 字

    阅读完需:约 19 分钟

本文要点

  • Web 页面中的图片往往是页面加载缓慢的最主要原因;
  • 图片优化很复杂,涉及大小调整、裁剪、格式转换及质量参数微调;
  • 如今,有的云服务可以即时优化图片,极大地改善用户浏览包含图片的 Web 页面时的体验;
  • 云服务提供了简单的 API 用于操作图片;
  • 读者可以立即应用其中的一项服务,毫不费力地提升网站性能。

图片往往是导致页面加载缓慢的最主要原因。一些研究表明,以兆字节计的Web 页面还在稳步增加,图片更是其中最大的部分。显然,大部分网站可以通过图片优化大幅提升性能。

本文将介绍如何使用 Kraken.io Cloudinary Imgix 三种不同的云服务,借助几行代码轻松实现图片的自动优。你可以立即使用这些服务中的一种减少网站图片文件的大小,大幅提高页面加载速度和带宽使用率。

图片优化涉及哪些方面?

在开始介绍如何自动优化图片之前,首先让我们了解下图片优化的基本要素:图片大小及调整、图片格式、图片质量或压缩。下面是图片优化的常见步骤,每一步对应其中一项要素:

  • 根据图片在 Web 页面上实际占用的空间调整图片大小及裁剪图片。我们认为,在浏览器端调整大小是不好的做法,因为那会强制用户无谓地下载大图片。
  • 将图片转换成最恰当的文件格式。对于不同类型的图片,情况可能会有所差别;在某些情况下,PNG 是最优的格式,而在其他情况下则是 JPEG。如果用户有一个现代浏览器,则可以使用那个浏览器支持的新文件格式。例如,只有 Chrome 支持的 WebP 格式,或者 IE9 及以上版本支持的 JPEG-XR 格式。
  • 优化目标文件格式的压缩。例如,JPEG 图片有一个质量设置。指定一个小于 100% 的质量百分比会压缩图片,但同时也会降低视觉品质。优化的艺术是找出不会导致可见质量损失的最高压缩水平(图片质量确实降低了,但只是轻微的,所以人根本注意不到)。确切的压缩阈值会因图片和格式的不同而有所差别。

另外一种优化是去掉文件中不必要的元数据。大部分照片都包含相机和图形应用存储的元数据,这增加了图片的大小,而且终端用户并不需要。本文将要介绍的所有图片优化服务都会同时去掉这类元数据。

上述步骤非常耗时,而且需要具备专业知识才能达到理想的效果。对于只有几张图片的网站而言,也许可以手工优化图片。不过,在现代网站上,一个页面就有几十或者几百张图片,所以,自动化是有必要的。

首先让我们看下如何手工优化图片。然后,我们将向你展示如何使用其中每一种云图片服务自动实现同样的优化。

下面是参考图片。这是一个 2048 X 1365 像素的 PNG 文件,大小为3975KB

图片来源: Marika Mariani on Flickr

为了让情况更复杂一些并充分利用不同工具的功能,我们假设这个横向图片需要刚好放入网页上用于放置肖像的纵向区域。下面是示例 Web 网页,借用了 Wikipedia 上的 Parrots 条目:

(点击查看大图)

为了优化这个图片并将其放到网页上,我们需要执行以下步骤:

  • 调整图片大小并进行裁剪,保证鹦鹉在可用区域里可见,而又不损失原始图片的长宽比。图片会明显变小。
  • 从 PNG 转换成一个对这个图片而言更有效的文件格式,如 JPEG。
  • 压缩图片,减少文件大小,而又不降低图片的视觉品质。

每个步骤都会明显减少文件大小,而又不会在视觉上降低质量。总之,如果我们调整图片大小,转换到一个更精简的文件格式,优化该格式的压缩参数,那么结果图片会是原始图片的一小部分。

现在让我们看下,如何使用三种图片管理服务的其中一种自动实现这种转换,并且看下它们在每个阶段可以将文件缩小多少。

请记住:这不是一个基准。图片内容不同,构图不同,优化后的文件大小可能会有差异。因此,这不是在对不同服务的有效性进行绝对测试,其有效性可能会因为图片类型的不同而不同。

使用 Kraken.io 优化图片

Kraken.io 是一项专门针对图片优化的云服务。其免费方案提供 100MB 的图片存储。

Kraken 提供一个 API,你可以通过编程上传图片,或者提供一个指向该图片的 URL。在调用这个 API 时,你可以给服务发送指令,让其对图片执行特定的优化,并下载优化后的新版本。

下面是使用 Kraken 优化鹦鹉图片的步骤:

1.注册Kraken 账户,安装相关SDK,验证自己的身份,并使用POST 请求将图片上传到Kraken。

使用Kraken 的PHP SDK,上传代码如下:

复制代码
$kraken = new Kraken("your-api-key", "your-api-secret");
$params = array(
"file" => "/path/to/image/parrot.jpg",
"wait" => true
);
$data = $kraken->upload($params);

2.上述代码只是上传图片。我们需要将图片大小调整到要求的尺寸(190 X 270 px),同时,我们还需要裁剪图片,以便我们可以把注意力集中在鹦鹉上,而又不损失长宽比;我们不能只是按照尺寸要求拉伸图片,因为那会使图片失真。

为了调整图片大小及裁剪,我们将修改上述代码,增加一些新参数。“strategy” => "fit"是指将图片大小调整到要求的尺寸,并保留原来的长宽比。“crop_mode” => "e"或"East"是说图片裁剪要以鹦鹉所在的右侧为重点。

复制代码
$params = array(
"resize" => array(
"width" => 190,
"height" => 270,
"strategy" => "fit",
"crop_mode" => "e"
)
);

API 调用的响应中包含一个 URL,你可以通过它下载优化后的文件。它看起来是下面这样:

文件大小已经降至 105KB,除了调整大小,还没有做其他任何优化。

注意:在默认情况下,Kraken API 会去掉图片的所有元数据,因为,当我们调整文件大小时,它会自动删除元数据,将文件大小降得更低一点。我们考察过的其他服务也是如此。

3.现在,让我们把格式从 PNG 转换成 JPEG:

复制代码
$params = array(
"convert" => array(
"format" => "jpeg",
"background" => "#ff0000"
)
)

修改后的 API 调用会返回一个不同的下载 URL,图片格式为 JPEG:

文件大小现在降至 88KB

4.最后,我们会优化 JPEG 图片的质量。这是像 Kraken 这样的图片优化解决方案的亮点所在。Kraken 提供了一个简单的参数 lossy。把这个参数添加到 API 调用的图片参数里,我们可以告诉 Kraken 将 JPEG 质量将至最低,而这种质量上的差异是人眼感觉不到的。

复制代码
$params = array(
"lossy" => true
)

结果看上去和上面的图片非常相似,但 JPEG 质量降低了:

新文件仅有 29KB,比 PNG 图片调整大小后减少了 72%。这只是由图片压缩带来的改善,因为我们之前已经调整了 PNG 图片的大小。

这是 Kraken 在不损失视觉感知品质的情况下所能做的最大压缩。原始文件大小为 3975KB,也就是说,在文件大小方面,新文件减少为原来的 1/137

5.一种更进一步的优化方法是将图片转换成最为优化的 WebP 文件格式,而不是 JPEG。不足之处是,只有 Chrome 浏览器支持 WebP。为此,我们将转换参数替换为 webp 参数,并保留 lossy 参数,将 WebP 图片的大小尽可能将至最低。

复制代码
$params = array(
"webp" => true,
"lossy" => true
)

结果看起来是这个样子(只有在Chrome 浏览器上可见)。

最终的WebP 文件只有 11KB,比调整大小后的 PNG 文件小89%,是原始文件的1/361

下面是使用 Kraken API 生成这个结果的完整 PHP 代码。最后一行代码获取 URL 下载优化后的图片。

复制代码
require_once("Kraken.php");
$kraken = new Kraken("your-api-key", "your-api-secret");
$params = array(
"file" => "/path/to/image/parrot.jpg",
"wait" => true
"resize" => array(
"width" => 190,
"height" => 270,
"strategy" => "fit",
"crop_mode" => "e"
"webp" => true,
"lossy" => true
);
$data = $kraken->upload($params);
$result = $data["kraked_url"];

注意:Kraken 郑重声明,结果 URL 不应该直接用在网站上,应用程序应该下载图片,保存在本地,并通过一个本地 URL 提供。

使用 Cloudinary 优化图片

Cloudinary 是一项执行图片优化的云图片服务,还提供各种各样的图片操作、云存储和 CDN 分发。Cloudinary 的免费方案提供 2GB 的云存储,75000 张图片,每月 7500 次图片转换。

Cloudinary 使用一种不同于 Kraken 的架构。在 Cloudinary 中,你将图片上传到永久云存储,然后 Cloudinary 服务会将图片直接分发给你的网站用户。

一个动态 URL 语言指定需要的图片操作或优化。当 URL 中有参数变化了,图片会即时调整,用户会看到调整后的图片。我们考察的另外一项服务 Imgix,使用了类似的方法。

下面是使用 Cloudinary 优化鹦鹉图片的步骤:

1.注册Cloudinary 账户,使用管理UI 上传图片,或者安装Cloudinary SDK,并使用upload 函数。在PHP SDK 中,代码类似下面这样:

复制代码
public static function upload($file, $options = array())

注意:和 Kraken 不同,我们不用在选项数组中传递图片操作参数,因为图片操作后续是即时完成的。Cloudinary 提供了额外的上传选项,包括客户端上传,让用户可以上传他们自己的图片。更多信息,请查看 Cloudinary 的 PHP 图片上传文档

2.让我们将图片调整并裁剪至 190 X 270px,并保持长宽比不变。

复制代码
cl_image_tag(
"parrot.png",
array(
"width"=>190,
"height"=>270,
"crop"=>"fill",
"gravity"=>"auto")
)
)

参数"gravity" => "auto"是 Cloudinary 的一项特性,即使用对象检测自动定位图片中最突出的的物体上。这是一种扩展性更好的方法,不需要针对每张图片调整参数。

上述代码生成了一个 HTML 图片标签,指向动态图片 URL,例如:

复制代码
<img src=”http://res.cloudinary.com/agile-seo/image/upload/h_270,w_190,c_fill,g_auto/parrot_marika_mariani.png”>

新文件大小为 103KB

3.我们将文件从 PNG 转换成 JPEG。在 Cloudinary 中,这只需要改变文件扩展名:

复制代码
cl_image_tag(
"parrot.jpg",
array(
"width"=>190,
...
)
)

现在,文件只有 27KB了。这已经远远低于我们对于全品质 JPEG 图片的预期了,这表明,Cloudinary 已经对图片进行了某些优化。

4.接下来,我们将通过添加"quality"=>"auto"参数全面优化 JPEG 质量:

复制代码
cl_image_tag(
"parrot.jpg",
array(
"quality"=>"auto"
)
)
)

现在,文件大小是 15KB,比调整大小后的 PNG 图片小了 85%

总得来说,Cloudinary 将原始文件的大小缩减为原来的 1/265

5.让我们将图片转换为更优化的文件格式。Cloudinary 提供了参数"format"=>“auto”,可以根据用户的浏览器动态设置图片格式(将图片即时转换成那种格式)。在 Chrome 浏览器上会自动生成 WebP 格式的图片。在新版本的 Explorer 上会生成 JPEG-XR 格式的。

请注意:文件扩展名仍然是“.jpg”,但实际上,文件格式是根据图片分析和用户浏览器自动确定的。如果你查看 Chrome 中的 URL 并下载图片,你就会看到,图片是 WebP 格式的。

经过质量优化的 WebP 格式的图片大小为12KB。Cloudinary 的 WebP 优化在文件大小上比优化后的 JPEG 小 20%。

还有一点需要特别注意,就是 Cloudinary通过 CDN 分发图片。这只是一种为了让用户更快地取回图片的额外优化,不会影响文件大小。

使用 Imgix 优化图片

Imgix 的工作原理与 Cloudinary 类似:上传图片,然后在你的代码中生成一个动态 URL,对图片执行不同的优化。和 Cloudinary 一样,Imgix 是一个全功能的图片管理解决方案,提供很多图片操作、云存储和 CDN 分发。

Imgix 提供了免费试用方案,允许用户基于 API 进行大约 3000 次图片操作。

下面是使用 Imgix 优化鹦鹉图片的步骤:

1.注册Imgix 账户。Imgix 不支持直接上传图片,因此,我们需要将图片放到一个已有的Web 文件夹下,并从Imgix 控制板连接过去。然后,就可以通过Imgix 子域名访问该图片了,即agileseo.imgix.com/my_image.png。

2.让我们裁剪并调整图片大小。使用 Imgix PHP SDK,生成动态图片 URL 的代码如下:

复制代码
use Imgix\UrlBuilder;
$builder = new UrlBuilder("demos.imgix.net");
$params = array(
"w" => 190,
"h" => 270,
"fit" => "crop",
"crop" => "edges",
);
echo $builder->createURL("parrot_marika_mariani.png", $params);

w、h、fit 和 crop 参数调整图片的大小,并聚焦于鹦鹉。Imgix 有一个“边缘检测”特性(由"crop" => "edges"激活),在裁剪图片的同时,可以聚焦于图片上最重要的部分。

结果图片的大小为 119KB

3.现在,我们将添加参数"fm" => “jpeg”,将图片转换成 JPEG 格式。

结果文件大小为 24KB

4.添加参数"auto" => “compress”,优化 JPEG 压缩。

最后,经过优化的JPEG 文件大小为 13KB,比调整大小后的 PNG 图片小 89%。

5.和 Cloudinary 一样,Imgix 提供了一个参数,可以根据图片和用户的浏览器自动选择最佳图片格式。参数是"auto" => “format”。

WebP 格式的文件竟然比压缩过的 JPEG 大,为24KB。这有点奇怪,但在我们看来,Imgix 不允许同时使用 compress 和 format 选项(我们试过了,没有效果),因此,当选择 auto=format 时,Imgix 会提供一张 WebP 图片,但没有优化压缩。

即使不进行 WebP 压缩,使用 JPEG 格式,Imgix 也可以将文件大小降至 1/305

和 Cloudinary 一样,Imgix通过 CDN 分发图片,这会额外提升用户取回图片的速度。

结果汇总:图片文件大小缩减了 250 倍

如上所述,本文不是为了提供一个基准,只是让你对自动化图片优化可以达到怎么样的文件大小缩减有一些认识。

下表汇总了我们使用这三种工具的优化结果。如上所述,虽然文件大小大幅缩减,图片质量有所下降,但所有服务生成的图片在视觉上都相当不错。

(点击放大图像)

有趣的是,对于这张特定的参考图片,Cloudinary 和Imgix 的JPEG 转换非常高效,它们几乎将文件大小降至WebP 图片的水平。图片内容、构图和复杂度不同,效果可能会有所差异。

实现图片自动优化的动机很明确:毫不费力地即时缩减图片大小,大幅提升网站的性能。我们考察的三项服务全都非常简单,并且提供了免费试用方案,我们建议你试下这些服务,让你的网站保持良好的状态。

你知道其他自动优化图片的工具或方法吗?或者对于我们考察的服务,你有什么想法吗?请在评论里和我们分享!

关于作者

Gilad David Maayan是一名技术作者,帮助领先的技术品牌把他们的产品介绍给新的受众。他还是 Agile SEO 的 CEO 兼联合创始人,他们通过搜索引擎将开发人员、IT 领导者和相关内容汇集在一起。

查看英文原文: 3 Easy Solutions to Optimize Images on the Fly

2017-09-20 17:397486
用户头像

发布了 1008 篇内容, 共 396.9 次阅读, 收获喜欢 345 次。

关注

评论 3 条评论

发布
用户头像
mark

2022-07-21 09:51
回复
用户头像
mark
2019-04-12 08:01
回复
用户头像
mark
2019-04-12 08:01
回复
没有更多了
发现更多内容

【C语言】前言关键字

謓泽

11月月更

华为云从入门到实战 | 负载均衡服务原理

TiAmo

华为 华为云 10月月更

怎样刷vue面试题

bb_xiaxia1998

Vue

从react源码看hooks的原理

flyzz177

React

面试官:请实现Javascript发布-订阅模式

helloworld1024fd

JavaScript

探究Presto SQL引擎(4)-统计计数

vivo互联网技术

浏览器 presto 引擎

PaddleBox:百度基于GPU的超大规模离散DNN模型训练解决方案

百度Geek说

企业号十月 PK 榜 PaddlePaddl 模型训练框架 大规模离散模型

11月月更开启啦!冬天到了,不写点东西暖暖身子吗?

InfoQ写作社区官方

热门活动 11月月更

珠宝加工厂:我的成本下降空间在哪里

华为云开发者联盟

云计算 物联网 华为云 企业号十月 PK 榜

没想到GoFrame的gcache天然支持缓存淘汰策略

王中阳Go

Go golang 高效工作 学习方法 11月月更

关于“React 和 Vue 该用哪个”我真的栓Q

京东科技开发者

Vue 前端 Vue 3 VUE 3.0 源码 react rout

Wallys//IPQ8072/IPQ8074/IPQ8072A/IPQ8074A/HighPower 802.11ax SoC for Routers, Gateways and Access Points

Cindy-wallys

802.11AX IPQ8072 IPQ8074 HighPower

云小课|MRS基础原理之MapReduce介绍

华为云开发者联盟

大数据 华为云 企业号十月 PK 榜

看透react源码之感受react的进化

goClient1992

React

Vue是怎样监听数组的变化的?

bb_xiaxia1998

Vue

Docker不香吗?为什么还要用k8s

源字节1号

微信小程序 软件开发 前端开发 后端开发

深度讲解React Props

夏天的味道123

React

Vue.$nextTick的原理是什么-vue面试进阶

bb_xiaxia1998

Vue

react的useState源码分析

flyzz177

React

深度理解Redux原理并实现一个redux

夏天的味道123

React

从recat源码角度看setState流程

flyzz177

React

以开发之名 | 小红书:用年轻人的方式开发年轻人喜欢的应用

HarmonyOS SDK

视频超分 小红书

前端高频手写题自测,你能做出几道

helloworld1024fd

JavaScript

应用实践:Paddle分类模型大集成者[PaddleHub、Finetune、prompt]

汀丶人工智能

nlp 文本分类 关系抽取 命名实体识别 11月月更

京东云开发者|提高IT运维效率,深度解读京东云AIOps落地实践

京东科技开发者

人工智能 异常检测 时序架构 运维‘

高频js手写题之实现数组扁平化、深拷贝、总线模式

helloworld1024fd

JavaScript

React-Hooks源码深度解读

goClient1992

React

这可能是你需要的vue考点梳理

bb_xiaxia1998

Vue

爆肝整理高频js手写题请查收

helloworld1024fd

JavaScript

案例解读华为隐私计算产品TICS如何实现城市跨部门数据隐私计算

华为云开发者联盟

云计算 华为云 隐私计算 企业号十月 PK 榜

探索行为可回溯系统的应用与实现

GFE

前端 监控

图片即时优化的三种简单解决方案_HTML5_Gilad David Maayan_InfoQ精选文章