#image #dimension #size #file-format #metadata #reading-file #file-metadata

imagesize

Quick probing of image dimensions without loading the entire file

32 releases

0.13.0 Jun 18, 2024
0.12.0 May 11, 2023
0.11.0 Jan 6, 2023
0.10.1 Sep 24, 2022
0.3.5 May 17, 2017

#18 in Images

Download history 49098/week @ 2024-08-22 51792/week @ 2024-08-29 55487/week @ 2024-09-05 53645/week @ 2024-09-12 53633/week @ 2024-09-19 60476/week @ 2024-09-26 61605/week @ 2024-10-03 52691/week @ 2024-10-10 64386/week @ 2024-10-17 63547/week @ 2024-10-24 68437/week @ 2024-10-31 57642/week @ 2024-11-07 53761/week @ 2024-11-14 59693/week @ 2024-11-21 62636/week @ 2024-11-28 51263/week @ 2024-12-05

235,329 downloads per month
Used in 281 crates (21 directly)

MIT license

58KB
1K SLoC

crates.io version docs-badge

imagesize

Quickly probe the size of various image formats without reading the entire file.

The goal of this crate is to be able to read the dimensions of a supported image without loading unnecessary data, and without pulling in more dependencies. Most reads only require 16 bytes or less, and more complex formats take advantage of skipping junk data.

Usage

Add the following to your Cargo.toml:

[dependencies]
imagesize = "0.13"

Supported Image Formats

  • Aseprite
  • Avif
  • BMP
  • DDS
  • EXR
  • Farbfeld
  • GIF
  • HDR
  • HEIC / HEIF
  • ICO*
  • ILBM (IFF)
  • JPEG
  • JPEG XL
  • KTX2
  • PNG
  • PNM (PBM, PGM, PPM)
  • PSD / PSB
  • QOI
  • TGA
  • TIFF
  • VTF
  • WEBP

If you have a format you think should be added, feel free to create an issue.

*ICO files can contain multiple images, imagesize will give the dimensions of the largest one.

Examples

From a file

match imagesize::size("example.webp") {
    Ok(size) => println!("Image dimensions: {}x{}", size.width, size.height),
    Err(why) => println!("Error getting dimensions: {:?}", why)
}

From a vector

let data = vec![0x47, 0x49, 0x46, 0x38, 0x39, 0x61, 0x64, 0x00, 0x64, 0x00];
match imagesize::blob_size(&data) {
    Ok(size) => println!("Image dimensions: {}x{}", size.width, size.height),
    Err(why) => println!("Error getting dimensions: {:?}", why),
}

No runtime deps