#file-format #reading #tiff #different #general #viewer #thermogram

libblackbody

Libblackbody is library for reading different thermographic file formats

6 releases (breaking)

0.5.0 Jan 2, 2021
0.4.0 Dec 31, 2020
0.3.1 Dec 24, 2020
0.3.0 Oct 13, 2020
0.1.0 Oct 12, 2020

#2212 in Parser implementations

EUPL-1.2

535KB
19K SLoC

libblackbody

This the library libblackbody which intends to be a general purpose thermogram file reading library. Currently it supports TIFF files and some FLIR cameras. It is used by Blackbody, a simple thermogram viewer.

Support for FLIR files is provided by the flyr library. A list of supported cameras can be found in the project repository's README. Tiff files are read making use of image-rs/tiff.

Installation

This library is available on crates.io. Install by adding it to your Cargo.toml.

Usage

Call Thermogram::from_file on your file:

let file_path = "/home/user/FLIR0123.jpg";
let r_thermogram = Thermogram::from_file(&file_path);
match r_thermogram {
    None => println!("Failed opening thermogram {:?}", file_path),
    Some(thermogram) => {
        println!("Successfully opened thermogram {:?}", file_path);
        // Do something with `thermogram`
        // ...
    },
}

The file is allowed to be a TIFF or a FLIR jpeg.

Interface of a thermogram

The methods listed below are available and recommended for use.

pub trait ThermogramTrait {
    fn thermal(&self) -> &Array<f32, Ix2>;  // The thermal data
    fn optical(&self) -> &Array<u8, Ix3>>;  // CHECK
    fn identifier(&self) -> &str;  // A uniquely identifying string for this thermogram
    fn render(&self min_temp: f32, max_temp: f32, palette: [[f32; 3]; 256]) -> Array<u8, Ix3>;  // Thermal data render using the given palette
    fn thermal_shape(&self) -> [usize; 2];  // The [height, width] of the thermal data
    fn normalized_minmax(&self) -> Array<f32, Ix2>;  // Thermal data normalized to lie in the range 0.0..=1.0
}

Issue tracking

Issue tracking happens in the Blackbody repository.

Dependencies

~15MB
~113K SLoC