Module image::codecs

source ·
Expand description

Encoding and decoding for various image file formats.

Supported formats

FormatDecodingEncoding
AVIFOnly 8-bitLossy
BMPYesRgb8, Rgba8, Gray8, GrayA8
DDSDXT1, DXT3, DXT5No
FarbfeldYesYes
GIFYesYes
HDRYesYes
ICOYesYes
JPEGBaseline and progressiveBaseline JPEG
OpenEXRRgb32F, Rgba32F (no dwa compression)Rgb32F, Rgba32F (no dwa compression)
PNGAll supported color typesSame as decoding
PNMPBM, PGM, PPM, standard PAMYes
QOIYesYes
TGAYesRgb8, Rgba8, Bgr8, Bgra8, Gray8, GrayA8
TIFFBaseline(no fax support) + LZW + PackBitsRgb8, Rgba8, Gray8
WebPYesRgb8, Rgba8

A note on format specific features

One of the main goals of image is stability, in runtime but also for programmers. This ensures that performance as well as safety fixes reach a majority of its user base with little effort. Re-exporting all details of its dependencies would run counter to this goal as it linked all major version bumps between them and image. As such, we are wary of exposing too many details, or configuration options, that are not shared between different image formats.

Nevertheless, the advantage of precise control is hard to ignore. We will thus consider wrappers, not direct re-exports, in either of the following cases:

  1. A standard specifies that configuration x is required for decoders/encoders and there exists an essentially canonical way to control it.
  2. At least two different implementations agree on some (sub-)set of features in practice.
  3. A technical argument including measurements of the performance, space benefits, or otherwise objectively quantified benefits can be made, and the added interface is unlikely to require breaking changes.

Features that fulfill two or more criteria are preferred.

Re-exports of dependencies that reach version 1 will be discussed when it happens.

Modules

  • Decoding of Radiance HDR Images
  • Decoding and Encoding of PNG Images