1000/1000
Hot
Most Recent
WebP is an image file format developed by Google intended as a replacement for JPEG, PNG, and GIF file formats. It supports both lossy and lossless compression, as well as animation and alpha transparency. Google announced the WebP format in September 2010, and released the first stable version of its supporting library in April 2018.
WebP was first announced by Google on 30 September in 2010 as a new open format for lossy compressed true-color graphics on the web, producing files that were smaller than JPEG files for comparable image quality.[1] It was based on technology which Google had acquired with the purchase of On2 Technologies.[2] As a derivative of the VP8 video format, it is a sister project to the WebM multimedia container format.[3] WebP-related software is released under a BSD free software license.[4]
On 3 October 2011,[5] Google added an "Extended File Format"[6] allowing WebP support for animation, ICC profile, XMP and Exif metadata, and tiling (compositing very large images from maximum 16384×16384 tiles). Older animated GIF files can be converted to animated WebP.
On 18 November 2011, Google announced a new lossless compression mode, and support for transparency (alpha channel) in both lossless and lossy modes; support was enabled by default in libwebp 0.2.0 (16 August 2012).[7][8] According to Google's measurements in November 2011, a conversion from PNG to WebP resulted in a 45% reduction in file size when starting with PNGs found on the web, and a 28% reduction compared to PNGs that are recompressed with pngcrush and PNGOUT.[9]
In July 2016, Apple added WebP support to early beta versions of macOS Sierra and iOS 10,[10] but support was later removed in the GM seed versions of iOS 10 and macOS Sierra released in September 2016. In September 2020, WebP support was added in Safari version 14.[11]
The supporting libwebp library reached version 1.0 in April 2018.[12]
As of November 2021, web browsers that support WebP had 96% market share.[13]
Bytes | Content | |||
---|---|---|---|---|
0–3 | R | I | F | F |
4–7 | length + 12 | |||
8–11 | W | E | B | P |
12–15 | V | P | 8 | (space) [14] |
16–19 | length (padded) | |||
20–… | VP8 key frame | |||
pad | ? (even length) |
WebP's lossy compression algorithm is based on the intra-frame coding of the VP8 video format[15] and the Resource Interchange File Format (RIFF) as a container format.[16] As such, it is a block-based transformation scheme with eight bits of color depth and a luminance–chrominance model with chroma subsampling by a ratio of 1:2 (YCbCr 4:2:0).[17] Without further content, the mandatory RIFF container has an overhead of only twenty bytes, though it can also hold additional metadata.[16] The side length of WebP images is limited to 16383 pixels.[18]
WebP is based on block prediction. Each block is predicted on the values from the three blocks above it and from one block to the left of it (block decoding is done in raster-scan order: left to right and top to bottom). There are four basic modes of block prediction: horizontal, vertical, DC (one color), and TrueMotion. Mispredicted data and non-predicted blocks are compressed in a 4×4 pixel sub-block with a discrete cosine transform or a Walsh–Hadamard transform. Both transforms are done with fixed-point arithmetic to avoid rounding errors. The output is compressed with entropy encoding.[17] WebP also has explicit support for parallel decoding.[17]
The reference implementation consists of converter software in the form of a command-line program for Linux (cwebp) and a programming library for the decoding, the same as for WebM. The open-source community ported the converter to other platforms, such as Windows.[19]
The WebP container (i.e., RIFF container for WebP) allows feature support over and above the basic use case of WebP (i.e., a file containing a single image encoded as a VP8 key frame). The WebP container provides additional support for:
WebP's lossless compression, a newer algorithm unrelated to VP8, was designed by Google software engineer Jyrki Alakuijala. It uses advanced techniques such as dedicated entropy codes for different color channels, exploiting 2D locality of backward reference distances and a color cache of recently used colors. This complements basic techniques such as dictionary coding, Huffman coding and color indexing transform.[7] This format uses a recursive definition: all of the control images, such as the local entropy code selection, are encoded the same way as the whole image itself.[20]
Google has proposed using WebP for animated images as an alternative to the popular GIF format, citing the advantages of 24-bit color with transparency, combining frames with lossy and lossless compression in the same animation, and support for seeking to specific frames.[21] Google reports a 64% reduction in file size for images converted from animated GIFs to lossy WebP, however, with a very noticeable visual impact, both at default settings, and optimised settings. When converting using lossless WebP, a 19% reduction is achieved as reported by Google,[21] although real world performance is nearer to 10%.[22]
Google actively promotes WebP, and Google Chrome and all Chromium-based browsers support the format. The proprietary PageSpeed Insights tool suggests that webmasters switch from JPEG and PNG to WebP in order to improve their website speed score.[23]
Microsoft Edge versions released after January 2020 are based on the Chromium browser, and have native WebP support. EdgeHTML-based versions of Microsoft Edge support WebP through a platform extension (installed by default) (unless running in the security-hardened "Application Guard" mode, which does not support platform extensions).[24]
Safari added support for WebP with iOS 14 and macOS Big Sur.[11]
Mozilla Firefox[25] (and its forks Pale Moon[26] and Waterfox[27]) officially supports WebP since January 2019.[28] It was initially considered for implementation in 2013.[29]
GNOME Web, Midori, and Falkon natively support WebP.
WebP can also be displayed in all major browsers using the WebPJS JavaScript library, although support in Internet Explorer 6 and above is achieved using Flash.[30]
Support for WebP was added to Links in version 2.26.[31]
Picasa (from version 3.9),[32] PhotoLine,[33] Pixelmator,[34] ImageMagick,[35] XnView,[36] IrfanView,[37] GDAL,[38] Aseprite,[39] Paint.NET (from version 4.2.5),[40] GIMP (from version 2.10),[41] gThumb (from version 3.1.1),[42] Xara Designer Pro (from version 18.0),[43] Adobe Photoshop (from version 23.2)[44] and GraphicConverter[45] all natively support WebP.
In 2019, Google released a free plug-in that enables WebP support in earlier versions of Adobe Photoshop.[46] Free Photoshop plug-ins had been released by Telegraphics and fnordware before that.[47][48] GIMP up to version 2.8 also supported WebP via a plugin;[49] later, this plugin was shipped in GIMP 2.9 branch, and received multiple improvements.[50] Google has also released a plug-in for Microsoft Windows[51] that enables WebP support in Windows Photo Viewer, Microsoft Office 2010, FastPictureViewer,[52] and any other application that uses Windows Imaging Component.[53] Blender supports WebP since version 3.2.[54]
FFmpeg linked with the VP8/VP9 reference codec library libvpx can extract VP8 key frames from WebM media and a script can then add the WebP RIFF header and the NUL pad byte for odd frame lengths. Meanwhile, FFmpeg supports libwebp directly.
Gmail and Google Photos both support WebP. Support for WebP is also planned for Google App Engine. The Instant Previews feature of Google Search uses WebP internally to reduce disk space used by previews.[55] Android 4.0 supports encoding and decoding WebP images (via bitmap and Skia).[56] SDL_image supports the format since 1.2.11.
Telegram Messenger uses WebP for their Stickers, claiming they are displayed 5 times faster compared to the other formats usually used in messaging apps.[57]
Signal uses WebP for their non-animated stickers.[58]
LibreOffice supports the import of WebP images since version 7.4,[59] so does the LibreOffice technology based online office Collabora Online.
Content management systems (CMS) usually do not support WebP natively or by default. However, for most popular CMS, extensions are available for automated conversion from other image formats to WebP and delivering WebP images to compatible browsers. Since June 2021, WordPress supports WebP natively.[60]
Like VP8 on which it is based, former lossy WebP supports only 8-bit YUV 4:2:0 format,[61] which may cause color loss on images with thin contrast elements (such as in pixel art and computer graphics) and ghosting in anaglyph. To overcome this restriction, new lossless WebP supports VP8L encoding that works exclusively with 8-bit RGBA (red, green, blue, alpha) color space.[62][63]
In September 2010, Fiona Glaser, a developer of the x264 encoder, wrote a very early critique of WebP.[15] Comparing different encodings (JPEG, x264, and WebP) of a reference image, she stated that the quality of the WebP-encoded result was the worst of the three, mostly because of blurriness on the image. Her main remark was that "libvpx, a much more powerful encoder than ffmpeg's jpeg encoder, loses because it tries too hard to optimize for PSNR" (peak signal-to-noise ratio), arguing instead that "good psycho-visual optimizations are more important than anything else for compression".[15]
In October 2013, Josh Aas from Mozilla Research published a comprehensive study of current lossy encoding techniques[64] and was not able to conclude that WebP outperformed mozjpeg by any significant margin.[65]
Google has been developing the second version of WebP since June 2021. Its reference implementation is libwebp2
. The main goal of this new format is to reach similar compression ratios as AVIF while remaining faster to encode and decode.[66]