#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

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

#178 in Images

Download history 62/week @ 2024-09-13 56/week @ 2024-09-20 14/week @ 2024-09-27 11/week @ 2024-10-04 9/week @ 2024-10-11 3/week @ 2024-10-18 17/week @ 2024-11-01 10/week @ 2024-11-08 16/week @ 2024-11-15 36/week @ 2024-11-22 138/week @ 2024-11-29 130/week @ 2024-12-06 13/week @ 2024-12-13 1/week @ 2024-12-20

154 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