aboutsummaryrefslogtreecommitdiff
path: root/vendor/exr/examples/0c_read_rgba.rs
blob: a2126f8205d536c3591ab6111fc5bcbd0d710d68 (plain) (blame)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
extern crate exr;

/// `exr` offers a few simplified functions for the most basic use cases.
/// `read_first_rgba_layer_from_file` is a such a function, which loads rgba exr files.
/// To load the pixel data, you need to specify
/// how to create and how to set the pixels of your image.
fn main() {
    let image = exr::prelude::read_first_rgba_layer_from_file(
        "generated_rgba.exr",

        // instantiate your image type with the size of the image in file
        |resolution, _| {
            let default_pixel = [0.0, 0.0, 0.0, 0.0];
            let empty_line =  vec![ default_pixel; resolution.width() ];
            let empty_image =  vec![ empty_line; resolution.height() ];
            empty_image
        },

        // transfer the colors from the file to your image type,
        // requesting all values to be converted to f32 numbers (you can also directly use f16 instead)
        // and you could also use `Sample` instead of `f32` to keep the original data type from the file
        |pixel_vector, position, (r,g,b, a): (f32, f32, f32, f32)| {
            pixel_vector[position.y()][position.x()] = [r, g, b, a]
        },

    ).expect("run the `1_write_rgba` example to generate the required file");

    // printing all pixels might kill the console, so only print some meta data about the image
    println!("opened file generated_rgba.exr: {:#?}", image.layer_data.attributes);
}