#size #file-format #jpeg #file-info #format-file #header #image-size

bin+lib imageinfo

Rust library to get image size and format without loading/decoding

34 releases

new 0.7.27 Dec 2, 2024
0.7.26 Aug 5, 2024
0.7.24 Jul 31, 2024
0.7.16 Feb 19, 2024
0.5.0 Feb 7, 2022

#115 in Images

Download history 1/week @ 2024-08-18 1/week @ 2024-08-25 1/week @ 2024-09-01 64/week @ 2024-09-15 58/week @ 2024-09-22 11/week @ 2024-09-29 13/week @ 2024-10-06 8/week @ 2024-10-13 1/week @ 2024-10-20 26/week @ 2024-11-03 1/week @ 2024-11-10 18/week @ 2024-11-17 38/week @ 2024-11-24 151/week @ 2024-12-01

211 downloads per month
Used in 2 crates

MIT license

57KB
1.5K SLoC

imageinfo-rs

Rust library to get image size and format without loading/decoding.

The imageinfo don't get image format by file ext name, but infer by file header bytes and character.

A rewrite of c++ version imageinfo

Some test image files are from image-size. Many thanks to @netroy.

ci

Supported formats

  • avif
  • bmp
  • cur
  • dds
  • gif
  • hdr (pic)
  • heic (heif)
  • icns
  • ico
  • jpeg2000 code stream (j2k, j2c, jpc, jhc)
  • jpeg2000 (jp2, jpx, jph)
  • jpeg (jpg)
  • ktx
  • png
  • psd
  • qoi
  • svg
  • tga
  • tiff (tif)
  • webp
  • more coming...

Installation

See https://crates.io/crates/imageinfo

Example

use imageinfo::{ImageInfo};

fn main() {
    match ImageInfo::from_file_path("images/valid/bmp/sample.bmp") {
        Ok(info) => {
            println!("  - Ext       : {}", info.ext);
            println!("  - Full Ext  : {}", info.full_ext);
            println!("  - Size      : {}", info.size);
            println!("  - Mimetype  : {}", info.mimetype);
            println!("  - Entries   :");
            for size in info.entry_sizes.iter() {
                println!("    - {}", size);
            }
        }
        Err(err) => {
            println!("  - Err       : {}", err);
        }
    }
}

Pretty easy?

Don't be stingy with your star : )

Dependencies

~0.3–1MB
~21K SLoC