From Wikipedia, the free encyclopedia

An example WebP image
Filename extension
Internet media typeimage/webp[2]
Uniform Type Identifier (UTI)org.webmproject.webp[3]
Magic number52 49 46 46 xx xx xx xx 57 45 42 50 56 50 38[2]
Developed byGoogle
Initial release30 September 2010; 12 years ago (2010-09-30)[4]
Type of formatImage file format with lossless and lossy compression
Contained byResource Interchange File Format (RIFF)[5]
Open format?Yes[6]
Stable release
1.3.0 / 13 January 2023; 4 months ago (2023-01-13)[7]
Written inC
TypeDigital imaging
LicenseBSD license

WebP is a raster graphics file format developed by Google intended as a replacement for JPEG, PNG, and GIF file formats. It supports both lossy and lossless compression,[8] 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.[9] It was based on technology which Google had acquired with the purchase of On2 Technologies.[10] As a derivative of the VP8 video format, it is a sister project to the WebM multimedia container format.[11] WebP-related software is released under a BSD free software license.[12]

On 3 October 2011,[13] Google added an "Extended File Format"[14] allowing WebP support for animation, ICC profile, XMP and Exif metadata, and tiling (compositing very large images from maximum 16384×16384 tiles). Tiling support was never finalized and was removed from the spec again.[15] 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).[16][17] 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.[18]

In July 2016, Apple added WebP support to early beta versions of macOS Sierra and iOS 10,[19] 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.[20]

The supporting libwebp library reached version 1.0 in April 2018.[21]

As of November 2021, web browsers that support WebP had 96% market share.[22]


Simple WebP
Bytes Content
0–3 R I F F
4–7 length + 12
8–11 W E B P
12–15 V P 8 (space) [23]
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[24] and the Resource Interchange File Format (RIFF) as a container format.[4] 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).[25] Without further content, the mandatory RIFF container has an overhead of only twenty bytes, though it can also hold additional metadata.[4] The side length of WebP images is limited to 16383 pixels.[6]

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.[25] WebP also has explicit support for parallel decoding.[25]

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.[26]

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:

An image may have metadata stored in Exif or XMP formats.
An image may have transparency, i.e., an alpha channel.
Color profile
An image may have an embedded ICC profile as described by the International Color Consortium.

Lossless compression[edit]

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.[16] 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.[27]


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.[28] 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,[28] although real world performance is nearer to 10%.[29]


Web browsers[edit]

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.[30]

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).[31]

Safari added support for WebP in 2020 with iOS 14 and macOS Big Sur.[20]

Mozilla Firefox[32] (and its fork Waterfox[33]) officially supports WebP since January 2019.[34] It was initially considered for implementation in 2013.[35]

Pale Moon implemented initial support for WebP in 2016 with its version 26 milestone.[36]

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.[37]

Support for WebP was added to Links in version 2.26.[38]

Graphics software[edit]

Acorn (from version 7.0),[39] Picasa (from version 3.9),[40] PhotoLine,[41] Pixelmator,[42] ImageMagick,[43] XnView,[44] IrfanView,[45] GDAL,[46] Aseprite,[47] Paint.NET (from version 4.2.5),[48] GIMP (from version 2.10),[49] gThumb (from version 3.1.1),[50] Xara Designer Pro (from version 18.0),[51] Adobe Photoshop (from version 23.2)[52] and GraphicConverter[53] all natively support WebP.

In 2019, Google released a free plug-in that enables WebP support in earlier versions of Adobe Photoshop.[54] Free Photoshop plug-ins had been released by Telegraphics and fnordware before that.[55][56] GIMP up to version 2.8 also supported WebP via a plugin;[57] later, this plugin was shipped in GIMP 2.9 branch, and received multiple improvements.[58] Google has also released a plug-in for Microsoft Windows[59] that enables WebP support in Windows Photo Viewer, Microsoft Office 2010, FastPictureViewer,[60] and any other application that uses Windows Imaging Component.[61] Blender supports WebP since version 3.2.[62]

Other programs[edit]

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.[63] Android 4.0 supports encoding and decoding WebP images (via bitmap and Skia).[64] 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.[65]

Signal uses WebP for their non-animated stickers.[66]

LibreOffice supports the import of WebP images since version 7.4,[67] so does the LibreOffice technology based online office Collabora Online.

Godot Engine as of version 4.0 supports importing and exporting WebP images and uses WebP as its internal format for storing imported compressed textures.[68]

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.[69]


Like VP8 on which it is based, former lossy WebP supports only 8-bit YUV 4:2:0 format,[70] 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.[71][72]

However, due to the complexity of the compression, it is also significantly slower than other web image formats. It is therefore usually not advisable to process the images directly, as is the case with Web Map Services.[73]


In September 2010, Fiona Glaser, a developer of the x264 encoder, wrote a very early critique of WebP.[24] 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".[24]

In October 2013, Josh Aas from Mozilla Research published a comprehensive study of current lossy encoding techniques[74] and was not able to conclude that WebP outperformed mozjpeg by any significant margin.[75]

WebP 2[edit]

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.[76]

On October 12, 2022, Google changed WebP 2's development repository's README file to state that "WebP 2 will not be released as an image format" and began describing WebP 2 as a "playground for image compression experiments".[77]

See also[edit]

  • Comparison of graphics file formats
  • AVIF, an image format based on the AV1 video format[78]
  • BPG, an image format intended to be a more compression-efficient replacement for the JPEG image format, based on the intra-frame encoding of the High Efficiency Video Coding (HEVC) video compression standard, introduced in 2014.
  • FLIF, a discontinued lossless image format which claimed to outperform PNG, lossless WebP, lossless BPG and lossless JPEG2000 in terms of compression ratio, introduced in 2015. FLIF was superseded by JPEG XL.
  • HEIF, another image format based on HEVC.
  • From the Joint Photographic Experts Group:
    • JPEG-LS, an old but efficient lossless format, introduced in 1999.
    • JPEG 2000, an improvement intended to replace the older JPEG by the JPEG committee, introduced in 2000.
    • JPEG XR, an alternative to JPEG 2000 supporting HDR and wide gamut color spaces, introduced in 2009.
    • JPEG XL, particularly optimised for responsive web environments, so that content renders well on a wide range of devices. Moreover, it includes several features that help transition from the legacy JPEG format. JPEG XL was introduced at the end of 2020.
  • MNG and APNG, PNG-based animated image formats, supporting lossless 24-bit RGB color and 8-bit alpha channel.


  1. ^ "WEBP file extension". DotWhat.net. Retrieved 1 October 2010.
  2. ^ a b WebP Image Format Media Type Registration. IETF. I-D draft-zern-webp. Retrieved 7 July 2022.
  3. ^ "webP". Apple Developer Documentation: Uniform Type Identifiers. Apple Inc.
  4. ^ a b c Rabbat, Richard (30 September 2010). "WebP, a new image format for the Web". Chromium Blog. Retrieved 1 October 2010.
  5. ^ "RIFF Container". Google Code. Retrieved 1 October 2010.
  6. ^ a b "WebP FAQs". Google Code. Retrieved 6 October 2010.
  7. ^ Zern, James (13 January 2023). "libwebp 1.3.0". Chromium. Retrieved 17 May 2023.
  8. ^ Calore, Michael (1 October 2010). "Meet WebP, Google's New Image Format". Wired. Retrieved 5 October 2010.
  9. ^ "Comparative Study of WebP, JPEG and JPEG 2000". Google Code. Archived from the original on 4 October 2010. Retrieved 1 October 2010.
  10. ^ Shankland, Stephen (30 September 2010). "Google Offers JPEG Alternative for Faster Web - With WebP, Google hopes to drastically cut data-transfer barriers to Web browsing. But it's not easy to challenge JPEG's dominance". CNET News. CBS Interactive. Retrieved 18 February 2021.
  11. ^ Paul, Ryan (2 October 2010). "Google's New VP8-Based Image Format Could Replace JPEG". Ars Technica. Condé Nast. Retrieved 5 October 2010.
  12. ^ Rabbat, Richard (3 October 2010). "License/Patent clarification". Google Groups. Retrieved 11 March 2011.
  13. ^ Arora, Vikas (3 October 2011). "WebP-Mux (RIFF based container) framework". Google Groups. Retrieved 18 November 2011.
  14. ^ "WebP Container Specification". Google Developers. Retrieved 4 April 2020.
  15. ^ Zern, James (22 December 2014). "webp-container-spec: remove references to fragments". Retrieved 6 May 2023.
  16. ^ a b Alakuijala, Jyrki (30 August 2012). "Lossless and Transparency Modes in WebP". Google Developers Blog. Retrieved 6 September 2012.
  17. ^ Zern, James (16 August 2012). "Version 0.2.0". Chromium. Retrieved 6 January 2017.
  18. ^ Alakuijala, Jyrki; Arora, Vikas; Joshi, Urvang (18 November 2011). "Lossless and Transparency Encoding in WebP". Google Code Blog. Retrieved 18 November 2011.
  19. ^ Stephen Shankland (19 July 2016). "Apple tests Google graphics format to speed up websites". CNET. Retrieved 20 July 2016.
  20. ^ a b "Apple Developer Documentation - Safari 14 Release Notes". developer.apple.com. Retrieved 18 February 2021.
  21. ^ "libwebp 1.0.0 release". 21 April 2018. Retrieved 18 February 2021.
  22. ^ "Can I use... WebP image format". caniuse.com. Retrieved 19 November 2021.
  23. ^ WebP Container Specification: U+0020 for lossy images, and "L" for lossless images.
  24. ^ a b c Glaser, Fiona (30 September 2010). "H.264 and VP8 for still image coding: WebP?". Diary Of An x264 Developer. Archived from the original on 19 March 2015. Retrieved 1 October 2010.
  25. ^ a b c "VP8 Data Format and Decoding Guide" (PDF). 23 September 2010. Retrieved 2 October 2010.[permanent dead link]
  26. ^ "WebP for .NET". Codeplex. Microsoft. 1 October 2010. Archived from the original on 15 September 2021. Retrieved 5 May 2022.
  27. ^ Jyrki Alakuijala (16 September 2014). "WebP Lossless Bitstream Specification". Google Inc.
  28. ^ a b "Frequently Asked Questions". 21 February 2014. Retrieved 23 February 2014.
  29. ^ "GIF is (Finally) dead. Long live Webp". technedigitale.com. 24 July 2021. Retrieved 19 August 2021.
  30. ^ "Serve images in modern formats". Chrome Developers.
  31. ^ "WebP images won't load in Microsoft Edge with Application Guard". 14 November 2018. Retrieved 14 November 2018.
  32. ^ "Firefox 65 for developers - Mozilla | MDN". developer.mozilla.org.
  33. ^ Kontos, Alex. "Waterfox 54.0.1 Release (Windows, Mac & Linux)". Retrieved 19 November 2018.
  34. ^ "Firefox 65 supports Google's WebP Image format - gHacks Tech News". gHacks Technology News. 2 November 2018. Retrieved 20 January 2022.
  35. ^ Shankland, Stephen. "Why Mozilla had a change of heart about WebP images". CNET. Retrieved 20 January 2022.
  36. ^ Moonchild. "Pale Moon – Release Notes for Archived Versions". www.palemoon.org. Retrieved 19 November 2018.
  37. ^ "WebPJS – Google's new image format WebP for not supported browsers (with alpha-channel)". Retrieved 20 November 2011.
  38. ^ "Changelog". Retrieved 14 May 2022.
  39. ^ Mueller, Gus. "Acorn". Flying Meat Software. Flying Meat Software. Retrieved 15 December 2022.
  40. ^ "What's happening to Picasa, Picasa Web Albums, and the Picasa Web Albums API? - Picasa and Picasa Web Albums Help". support.google.com.
  41. ^ "Release notes Version 18.00". pl32.com. Retrieved 5 October 2013.
  42. ^ David, Chartier (4 October 2010). "Pixelmator to Add Support for Google's WebP Image Format". PC World. IDG. Retrieved 5 October 2010.
  43. ^ "ImageMagick Image Formats". ImageMagick.org. ImageMagick Studio LLC. Retrieved 24 May 2011.
  44. ^ "XnView Software – All Supported Formats". xnview.com. Pierre-Emmanuel Gougelet. Retrieved 6 January 2014.
  45. ^ "History of IrfanView changes/versions". www.irfanview.com.
  46. ^ "GDAL supported formats". gdal.org. GDAL – Geospatial Data Abstraction Library. Retrieved 30 November 2011.
  47. ^ "Aseprite – Release-notes". www.aseprite.org. Retrieved 28 March 2016.
  48. ^ "paint.net 4.2.5 is now available!". blog.getpaint.net. October 2019. Retrieved 1 October 2019.
  49. ^ "GIMP 2.10 Release Notes". www.gimp.org. Retrieved 2 May 2018.
  50. ^ "[gthumb-list] gThumb 3.1.1 released". Retrieved 2 May 2020.
  51. ^ "Release notes Version 18". Xara website. Retrieved 9 September 2021.
  52. ^ "Work with WebP files in Photoshop".
  53. ^ "Lemke Software: Import and export formats". www.lemkesoft.de.
  54. ^ "WebPShop". Photoshop plug-in for opening and saving WebP images. Google Inc. Retrieved 15 July 2019.
  55. ^ "WebP Format". Free plugins for Photoshop & Illustrator. Telegraphics. Retrieved 23 May 2011.
  56. ^ "Adobe WebM/WebP plugins". fnordware.com. Retrieved 29 June 2015.
  57. ^ "nathan-osman/gimp-webp: Gimp plugin for loading and saving WebP images". GitHub. Retrieved 30 March 2016.
  58. ^ "GIMP 2.9.6 Released". www.gimp.org. 24 August 2017. Retrieved 24 May 2018.
  59. ^ "WebP Codec Installer for Windows 0.19".
  60. ^ "FastPictureViewer Professional | Image File Formats Compatibility Chart". www.fastpictureviewer.com.
  61. ^ "WebP Codec for Windows". WebP website. Google Inc. Archived from the original on 5 May 2012. Retrieved 24 May 2011.
  62. ^ "Pipeline, Assets, IO". Retrieved 20 June 2022.
  63. ^ "The Chromium Blog: WebP in Chrome, Picasa, Gmail With a Slew of New Features and Improvements". 21 May 2011. Retrieved 20 May 2011.
  64. ^ "Android 4.0 Platform Highlights".
  65. ^ "Stickers Done Right". Telegram. 2 January 2015.
  66. ^ "Stickers – Signal Support".
  67. ^ "LibreOffice 7.4 Community: Release Notes - the Document Foundation Wiki".
  68. ^ "Add support for saving WebP images #61770". 21 June 2022.
  69. ^ "WordPress 5.8 adds WebP support". 7 June 2021.
  70. ^ "Format Overview". VP8 Data Format and Decoding Guide. IETF. November 2011. sec. 2. doi:10.17487/RFC6386. RFC 6386. Retrieved 21 January 2014.
  71. ^ "Frequently Asked Questions | WebP". Google Developers.
  72. ^ "Specification for WebP Lossless Bitstream". Google Developers.
  73. ^ "WebP Discussion Group: Compression time and file size". 16 February 2023. Retrieved 17 February 2023.
  74. ^ Josh Aas. "Studying Lossy Image Compression Efficiency". Mozilla Research Blog. Retrieved 10 September 2014.
  75. ^ Josh Aas. "Mozilla Advances JPEG Encoding with mozjpeg 2.0". Mozilla Research Blog. Retrieved 10 September 2014.
  76. ^ "codecs/libwebp2 - Git at Google". chromium.googlesource.com. 8 June 2021. Retrieved 16 June 2021. Updated from time to time.
  77. ^ Guyon, Yannis. "Diff - 1251ca748c17278961c0d0059b744595b35a4943". Google Git. Google LLC. Retrieved 30 October 2022.
  78. ^ "AV1 Still Image File Format (AVIF)". aomediacodec.github.io. Retrieved 10 October 2018.

External links[edit]