Web图像优化(2)

WebP

WebP是Google最近推出的一种图像格式,旨在以可接受的视觉质量提供较低文件大小的无损和有损压缩。它包括对alpha通道透明度和动画的支持。

在去年,WebP在有损和无损模式下比压缩方式增加了几个百分点,而速度方面,算法速度提高了一倍,解压缩了提升10%。

image

WebP如何运行

  • 有损压缩

使用VP8或VP9视频关键帧编码变体的WebP有损文件,平均比JPEG文件小25-34%。

低质量范围(0-50)中,WebP相对于JPEG具有很大优势,因为它可以消除丑陋的块状伪影。中等质量设置(-m 4 -q 75)是默认的平衡速度/文件大小。在更高的范围内(80-99),WebP的优势在缩小。 WebP被推荐在速度质量更重要的地方

(WebP有损品质设置不能直接与JPEG比较。 “70%质量”的JPEG与“70%质量”的WebP图像是完全不同的,因为WebP通过丢弃更多数据来实现更小的文件大小。)

  • 无损压缩
    WebP无损文件比PNG文件小26%。与PNG相比,无损加载时间减少了3%。你通常不徐要无损。无损边缘和锐利边缘(例如非JPEG)是有区别的。无损WebP可能更适合档案内容。

  • 透明度
    WebP有一个无损的8位透明通道,只有比PNG多22%的字节。它还支持有损RGB透明度,这是WebP独有的功能。

  • 元数据
    WebP文件格式支持EXIF照片元数据和XMP数字文档元数据。它还包含一个ICC颜色配置文件。

WebP提供了更好的压缩,但代价是CPU密集度更高。早在2013年,WebP的压缩速度比JPEG慢了10倍,但现在可以忽略不计(有些图像可能会慢两倍)。静态图像作为您的构建的一部分进行处理,这不应该是一个大问题。动态生成的图像可能会导致CPU超载,需要评估使用。

谁在生产中使用WebP?

image

Google使用WebP比其他有损压缩方案节省了30-35%的成本,每天处理430亿个图像请求,其中26%是无损压缩。如果浏览器支持更好,更广泛的话,节省无疑会更大。 Google也将其用于Google Play和YouTube等制作网站。

WebP如何编码?

WebP的有损编码被设计为与JPEG竞争。 WebP的有损编码有三个关键阶段

  • Macro-blocking
image

将图像分成16×16(宏)的亮度像素块和两个8×8色度像素块。色度通道下采样和图像细分的想法可能听起来很熟悉,与JPEG色彩空间转换类似。

  • Prediction
image

每个4×4子块具有有效进行滤波的预测模型。这定义了两个像素周围的像素 - A(正上方的行)和L(左侧的列)。使用这两个编码器填充4×4像素的测试块,并确定哪个创建最接近原始块的值。

离散余弦变换(DCT)应用了与JPEG编码类似的几个步骤。一个关键的区别是使用算术压缩器与JPEG的霍夫曼。

WebP浏览器情况

并不是所有的浏览器都支持WebP,但根据CanIUse.com的统计,全球用户支持率在74%左右。 Chrome和Opera本身就支持它。 Safari,Edge和Firefox已经尝试过,但尚未在官方发布的版本中发布。 这通常会让WebP图像给用户,直到Web开发人员。 稍后再说。

WebP并非没有缺点。 它缺少全分辨率色彩空间选项,不支持逐行解码。

如何将我的图像转换为WebP?

一些商业和开源图像编辑和处理软件包支持WebP。一个特别有用的应用是XnConvert:一个免费的,跨平台的批量图像处理转换器。

image

避免将低质量或平均质量的JPEG转换为WebP非常重要。 这是一个常见的错误,可以生成带有JPEG压缩工件的WebP图像。 这可能导致WebP的效率降低,因为它必须保存图像和JPEG添加的失真,导致质量下降两倍。 转换应用程序的最佳质量源文件,最好是原件。

脚本程序
imagemin是一个流行的图像缩小模块,也有一个用于将图像转换为WebP(imagemin-webp)的插件。这支持有损和无损模式。

有损转换

const imagemin = require('imagemin');
const imageminWebp = require('imagemin-webp');

imagemin(['images/*.{jpg}'], 'images', {
    use: [
        imageminWebp({quality: 60})
    ]
}).then(() => {
    console.log('Images optimized');
});

无损转换(pass lossless: true to options:)

const imagemin = require('imagemin');
const imageminWebp = require('imagemin-webp');

imagemin(['images/*.{jpg,png}'], 'build/images', {
    use: [
        imageminWebp({lossless: true})
    ]
}).then(() => {
    console.log('Images optimized');
});

也可以通过建立在imagemin-webp上的gulp插件和用于WebPack的WebP加载器来实现。 Gulp插件接受imagemin插件所做的任何选项:

有损转换

const gulp = require('gulp');
const webp = require('gulp-webp');

gulp.task('webp', () =>
    gulp.src('src/*.jpg')
    .pipe(webp({
        quality: 80,
        preset: 'photo',
        method: 6
    }))
    .pipe(gulp.dest('dist'))
);

无损转换(pass lossless: true to options:)

const gulp = require('gulp');
const webp = require('gulp-webp');

gulp.task('webp-lossless', () =>
    gulp.src('src/*.jpg')
    .pipe(webp({
        lossless: true
    }))
    .pipe(gulp.dest('dist'))
);

使用Bash进行批量图像优化

您可以使用cwebp将您的图像批量转换为WebP

find ./ -type f -name '*.jpg' -exec cwebp -q 70 {} -o {}.webp ;

使用jpeg-recompress批量优化您的图像来源与MozJPEG

find ./ -type f -name '*.jpg' -exec jpeg-recompress {} {} ;

并使用svgo修改这些SVG(我们将在后面介绍)

find ./ -type f -name '*.svg' -exec svgo {} ;

其他WebP图像处理和编辑应用程序

  • Leptonica
  • Sketch
    GIMP
    ImageMagick
    Pixelmator
    Photoshop WebP Plugin

如何查看我的操作系统上的WebP图像?

虽然您可以将WebP图像拖放到基于Blink的浏览器(Chrome,Opera,Brave)以进行预览,但也可以使用Mac或Windows的附加组件直接从操作系统预览它们。

在Mac上,请尝试WebP的Quick Look插件(qlImageSize)

在Windows上,您还可以下载WebP编解码器包,以便在“资源管理器”和“Windows照片查看器”中预览WebP图像。

如何为WebP提供服务?

没有支持WebP的浏览器可能最终不会显示图像,这是不理想的。为了避免这种情况,我们可以使用一些策略来基于浏览器支持有条件地提供WebP

使用.htaccess来提供WebP副本
以下是从您的服务器获取WebP图像到用户的一些选项

浏览器可以通过一个Accept头来显式地给WebP支持信号。如果你控制你的后端,你可以返回一个WebP版本的图像。但是这并不总是可能的(例如,对于像GitHub页面或S3这样的静态主机),所以一定要在考虑这个选项之前进行检查。

以下是Apache Web服务器.htaccess文件::

<IfModule mod_rewrite.c>

RewriteEngine On

# Check if browser support WebP images
RewriteCond %{HTTP_ACCEPT} image/webp

# Check if WebP replacement image exists
RewriteCond %{DOCUMENT_ROOT}/$1.webp -f

# Serve WebP image instead
RewriteRule (.+)\.(jpe?g|png)$ $1.webp [T=image/webp,E=accept:1]

</IfModule>

<IfModule mod_headers.c>

    Header append Vary Accept env=REDIRECT_accept

</IfModule>

如果页面上显示的.webp图像出现问题,请确保在您的服务器上启用了图像/ webp MIME类型。

将以下代码添加到.htaccess文件中:

AddType  image/webp .webp

Nginx:将以下代码添加到mime.types文件中

image/webp webp

浏览器使用<picture> 元素</picture>
浏览器本身能够通过使用<图片>标签来选择要显示的图片格式。 <picture>标签利用多个<source>元素和一个<img>标签,这是包含图片的实际DOM元素。浏览器遍历源代码并检索第一个匹配项。如果用户的浏览器不支持<picture>标签,则会呈现<div>,并使用<img>标签

请注意<source>的位置。 不要将图片/网页源放在旧格式之后,而应放在之前。 理解它的浏览器将使用它们,而那些不会使用更广泛支持的框架的浏览器将会使用它们。 如果文件大小相同(当不使用媒体属性时),也可以按照文件大小的顺序放置图像。 一般来说,这与最后放弃传统的顺序是一样的。

<picture>
  <source srcset="/path/to/image.webp" type="image/webp">
  <img src="/path/to/image.jpg" alt="">
</picture>

<picture>
    <source srcset='paul_irish.jxr' type='image/vnd.ms-photo'>
    <source srcset='paul_irish.jp2' type='image/jp2'>
    <source srcset='paul_irish.webp' type='image/webp'>
    <img src='paul_irish.jpg' alt='paul'>
</picture>

<picture>
   <source srcset="photo.jxr" type="image/vnd.ms-photo">
   <source srcset="photo.jp2" type="image/jp2">
   <source srcset="photo.webp" type="image/webp">
   <img src="photo.jpg" alt="My beautiful face">
</picture>

其他一些资源:

  • Automatic CDN conversion to WebP
  • WordPress WebP support
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 213,099评论 6 492
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 90,828评论 3 387
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 158,540评论 0 348
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 56,848评论 1 285
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 65,971评论 6 385
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,132评论 1 291
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,193评论 3 412
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 37,934评论 0 268
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,376评论 1 303
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,687评论 2 327
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 38,846评论 1 341
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,537评论 4 335
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,175评论 3 317
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 30,887评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,134评论 1 267
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 46,674评论 2 362
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 43,741评论 2 351

推荐阅读更多精彩内容