WebP

圖像文件格式的類型
(重定向自Webp

WebP(發音:weppy[6][7])是一種同時提供了有損壓縮無損壓縮(可逆壓縮)的圖片檔案格式[8]

WebP
扩展名
.webp[1]
互联网媒体类型
image/webp
首次发布2010年9月30日 (2010-09-30)[2]
最新版本
1.4.0[3]在维基数据编辑
2024年4月13日
使用容器資源交換檔案格式(RIFF)[4]
免费格式?[5]
网站developers.google.com/speed/webp/

WebP最初在2010年9月釋出,其支持库于2018年4月发布1.0版本。截至2021年5月,已有94%的浏览器支持此格式[9]

WebP的设计目標是在減少檔案大小的同时,達到和JPEGPNGGIF格式相同的圖片品質,并希望借此能夠減少圖片檔在網路上的傳送時間。[10]根據Google較早的測試,WebP的無損壓縮比網路上找到的PNG檔少了45%的檔案大小,即使這些PNG檔在使用pngcrush和PNGOUT處理過,WebP還是可以減少28%的檔案大小[11]

WebP支援的像素最大數量是16383x16383。有損壓縮的WebP僅支援8-bit的YUV 4:2:0格式。而無損壓縮(可逆壓縮)的WebP支援VP8L編碼與8-bit之RGBA色彩空間。而無論是有損或無損壓縮皆支援Alpha透明通道、ICC色彩配置、XMP詮釋資料。

WebP有靜態與動態兩種模式。動態WebP(Animated WebP)支援有損與無損壓縮、ICC色彩配置、XMP詮釋資料、Alpha透明通道。

历史

Google于2010年9月30日首次公布WebP格式,它衍生自影像編碼格式VP8[12],被認為是WebM多媒體格式的姊妹項目,是Google在購買On2 Technologies後获得技术發展而来的[13],该格式及其衍生的支持库以BSD授權條款釋出。[14]

2011年10月3日,Google给WebP添加了扩展格式以让其支持ICC色彩特性文件可扩展后设资料平台EXIF[15]

2011年11月8日,Google開始讓WebP支援無損壓縮和透明色(alpha通道)的功能,而在2012年8月16日的參考實做libwebp 0.2.0中正式支援[16][17]

截至2022年1月,已有94%的浏览器支持此格式[18]

技術

简单WebP
内容
 0- 3RIFF
 4- 7length+8
 8-11WEBP
12-15VP8[15]
16-19length (padded)
20- …VP8关键帧
pad(even length)

WebP的有损压缩算法是基于VP8视频格式的帧内编码英语Intra-frame coding[19],并以RIFF作为容器格式[2] 因此,它是一个具有八位色彩深度和以1:2的比例进行色度子采样亮度-色度模型YCbCr 4:2:0)的基于块的转换方案。[20] 不含内容的情况下,RIFF容器要求只需20字节的开销,依然能保存额外的元数据(metadata)。[2] WebP图像的边长限制为16383像素。[5]

WebP是基于块预测的。每个块都是根据它上面三个块的值和其左边一个块的值进行预测的(块解码以光栅扫描顺序完成:从左到右,从上到下)。块预测有四种基本模式:水平、垂直、DC(单色)和TrueMotion。利用离散余弦变换沃尔什-阿达玛转换将预测错误的数据和未预测块压缩在4×4像素子块中。这两种转换都是使用定点算术英语fixed-point arithmetic完成的,以避免舍入误差。输出使用熵编码进行压缩。[20] WebP也明确支持并行解码。[20]

参考实现包含一个Linux命令行程序的转换器,以及用于解码的,与WebM相同。开源社区很快设法将转换器移植到其他平台,例如Windows。[21]

WebP的无损压缩采用先进的技术,例如用于不同颜色通道的专用熵代码,利用反向参考距离的2D位置和最近使用的颜色的颜色缓存。这补充了字典编码、霍夫曼编码和颜色索引变换等基本技术。[17]

支援

浏览器

Chrome和所有基于Chromium的浏览器(如OperaBrave等)均原生支援靜態與動態的WebP格式[22][23],且自12版開始支援WebP的漸進式解碼功能[24]

从2020年1月后发布的基于Chromium的Edge版本原生支持WebP格式。在此之前基于EdgeHTML的Edge版本则在除安全应用保护模式外,通过默认安装的平台扩展实现支持[25]

Firefox和所有延伸自Firefox的浏览器(如Pale MoonWaterfox等)瀏覽器亦在65.0版本起支援WebP圖像。[26]

2020年9月,在iOS 14macOS Big SurSafari 14中加入了WebP支持。[27]

Linux中使用的GNOME WebKDE圖片瀏覽器Gwenview也支援WebP。

此外所有可以原生播放WebM影像的瀏覽器,也可以透過javascript來顯示WebP影像[28][29]。不过在Internet Explorer 6和以上版本中是通过Flash实现的。

图像软件

圖像軟體當中,Picasa(從3.9版本起)、PhotoLine英语PhotoLine[30]Pixelmator[31]ImageMagickXnViewIrfanViewGDAL[32]、Aseprite和GIMP(2.10起)皆原生支援WebP格式。

系统

Android 4.0 支持解码和编码 WebP 图像(通过位图和 Skia 引擎)。[33]

其他程序

FFmpeg 在链接 VP8/VP9 参考代码库 libvpx 的情况下可以从 WebM 视频提取 VP8 关键帧,并有脚本追加 WebP RIFF 标头,并对怪异的帧长度追加 NUL 填充字节。同时 FFmpeg 也支持直接使用 libwebp。

Gmail 和 Google 相册都支持 WebP。

Sumatra PDF 从2.4版开始支持 WebP。[34]

Telegram 将 WebP 用于他们的表情符號,声称它们的显示速度比消息应用程序中通常使用的其他格式快5倍[35]

Signal 在非动态图片贴纸中使用 WebP 格式。[36]

LibreOffice 从7.4版本开始支持导入及导出 WebP 图像,[37]采用同样技术的 Collabora Online 也获得这一格式的支持。

Godot 引擎 4.0 版支持导入及导出 WebP 图像,并使用 WebP 作为编排已导入的压缩纹饰图像的内部格式。[38]

評論

x264的開發者之一:Jason Garrett-Glaser,在2010年時針對WebP做出了幾點評論[39],根據和其他編碼器(JPEG、x264、Theora)測試的結果,他認為WebP的影像品質是最差的,多數是在模糊度方面。他也評論Google應該等到WebP可以超越JPEG之後再發佈。不過在2011年4月20日,他提到新的WebP編碼器表現的非常好,超越JPEG指日可待。

WebP 2

WebP 2是Google自2021年6月起开发的新一代WebP。它的具体实现为libwebp2。这种新格式的主要目标是达到与AV1类似的压缩比,并同时保有更快的编码和解码速度[40]

相關條目

參考文獻

外部連結