Skip to main content

ImageBuffer

Struct ImageBuffer 

Source
pub struct ImageBuffer<'a> { /* private fields */ }
Expand description

Borrowed wrapper around a caller-owned image buffer.

Implementations§

Source§

impl<'a> ImageBuffer<'a>

Source

pub fn from_argb8888( data: &'a mut [u8], width: usize, height: usize, ) -> Result<Self>

Examples found in repository?
examples/02_blas_vimage.rs (line 31)
5fn main() {
6    let mut output = vec![0.0_f32; 4];
7    sgemm_row_major(
8        2,
9        2,
10        3,
11        1.0,
12        &[1.0, 2.0, 3.0, 4.0, 5.0, 6.0],
13        &[7.0, 8.0, 9.0, 10.0, 11.0, 12.0],
14        0.0,
15        &mut output,
16    )
17    .expect("sgemm failed");
18    let expected = [58.0_f32, 64.0, 139.0, 154.0];
19    for (actual, expected_value) in output.iter().zip(expected) {
20        assert!(
21            (actual - expected_value).abs() < 1.0e-5,
22            "unexpected sgemm output: {output:?}"
23        );
24    }
25
26    let source_pixels = vec![
27        255_u8, 10, 20, 30, 255, 40, 50, 60, 255, 70, 80, 90, 255, 100, 110, 120,
28    ];
29    let mut src_pixels = source_pixels.clone();
30    let mut rotated_pixels = vec![0_u8; source_pixels.len()];
31    let src = ImageBuffer::from_argb8888(&mut src_pixels, 2, 2).expect("src buffer");
32    let mut rotated =
33        ImageBuffer::from_argb8888(&mut rotated_pixels, 2, 2).expect("rotated buffer");
34    rotate_argb8888(
35        &src,
36        &mut rotated,
37        0.0,
38        [0, 0, 0, 0],
39        vimage_flags::NO_FLAGS,
40    )
41    .expect("rotate failed");
42    assert_eq!(rotated_pixels, source_pixels);
43
44    let mut planar_src = vec![10_u8, 20, 30, 40];
45    let mut planar_dst = vec![0_u8; 4];
46    let planar_src_buffer = ImageBuffer::from_planar8(&mut planar_src, 2, 2).expect("planar src");
47    let mut planar_dst_buffer =
48        ImageBuffer::from_planar8(&mut planar_dst, 2, 2).expect("planar dst");
49    contrast_stretch_planar8(
50        &planar_src_buffer,
51        &mut planar_dst_buffer,
52        vimage_flags::NO_FLAGS,
53    )
54    .expect("contrast stretch failed");
55    assert_eq!(planar_dst, vec![0, 85, 170, 255]);
56
57    println!("blas+vimage smoke passed: sgemm={output:?} contrast={planar_dst:?}");
58}
More examples
Hide additional examples
examples/08_vimage_processing.rs (line 9)
6fn main() {
7    let mut source = vec![255_u8, 10, 20, 30];
8    let mut scaled = vec![0_u8; 16];
9    let src = ImageBuffer::from_argb8888(&mut source, 1, 1).expect("src");
10    let mut dst = ImageBuffer::from_argb8888(&mut scaled, 2, 2).expect("dst");
11    scale_argb8888(&src, &mut dst, vimage_flags::NO_FLAGS).expect("scale");
12    for pixel in scaled.chunks_exact(4) {
13        assert_eq!(pixel, &[255, 10, 20, 30]);
14    }
15
16    let mut interleaved = vec![255_u8, 10, 20, 30, 128, 40, 50, 60];
17    let mut alpha = vec![0_u8; 2];
18    let mut red = vec![0_u8; 2];
19    let mut green = vec![0_u8; 2];
20    let mut blue = vec![0_u8; 2];
21    let src_interleaved = ImageBuffer::from_argb8888(&mut interleaved, 2, 1).expect("src interleaved");
22    let mut alpha_plane = ImageBuffer::from_planar8(&mut alpha, 2, 1).expect("alpha");
23    let mut red_plane = ImageBuffer::from_planar8(&mut red, 2, 1).expect("red");
24    let mut green_plane = ImageBuffer::from_planar8(&mut green, 2, 1).expect("green");
25    let mut blue_plane = ImageBuffer::from_planar8(&mut blue, 2, 1).expect("blue");
26    convert_argb8888_to_planar8(
27        &src_interleaved,
28        &mut alpha_plane,
29        &mut red_plane,
30        &mut green_plane,
31        &mut blue_plane,
32        vimage_flags::NO_FLAGS,
33    )
34    .expect("deinterleave");
35
36    let alpha_plane = ImageBuffer::from_planar8(&mut alpha, 2, 1).expect("alpha src");
37    let red_plane = ImageBuffer::from_planar8(&mut red, 2, 1).expect("red src");
38    let green_plane = ImageBuffer::from_planar8(&mut green, 2, 1).expect("green src");
39    let blue_plane = ImageBuffer::from_planar8(&mut blue, 2, 1).expect("blue src");
40    let mut reinterleaved = vec![0_u8; 8];
41    let mut dst_interleaved = ImageBuffer::from_argb8888(&mut reinterleaved, 2, 1).expect("dst interleaved");
42    convert_planar8_to_argb8888(
43        &alpha_plane,
44        &red_plane,
45        &green_plane,
46        &blue_plane,
47        &mut dst_interleaved,
48        vimage_flags::NO_FLAGS,
49    )
50    .expect("reinterleave");
51    assert_eq!(reinterleaved, interleaved);
52
53    let mut clip_source = vec![64_u8, 100, 50, 10];
54    let mut clip_dest = vec![0_u8; 4];
55    let src_clip = ImageBuffer::from_argb8888(&mut clip_source, 1, 1).expect("clip src");
56    let mut dst_clip = ImageBuffer::from_argb8888(&mut clip_dest, 1, 1).expect("clip dst");
57    clip_to_alpha_argb8888(&src_clip, &mut dst_clip, vimage_flags::NO_FLAGS).expect("clip");
58    assert_eq!(clip_dest, vec![64, 64, 50, 10]);
59
60    let mut planar_src = vec![5_u8, 15, 25, 35];
61    let mut planar_dst = vec![0_u8; 4];
62    let src_planar = ImageBuffer::from_planar8(&mut planar_src, 2, 2).expect("planar src");
63    let mut dst_planar = ImageBuffer::from_planar8(&mut planar_dst, 2, 2).expect("planar dst");
64    contrast_stretch_planar8(&src_planar, &mut dst_planar, vimage_flags::NO_FLAGS)
65        .expect("stretch");
66    assert_eq!(planar_dst, vec![0, 85, 170, 255]);
67
68    println!("vimage smoke passed: scaled={scaled:?} reinterleaved={reinterleaved:?} clipped={clip_dest:?}");
69}
Source

pub fn from_planar8( data: &'a mut [u8], width: usize, height: usize, ) -> Result<Self>

Examples found in repository?
examples/02_blas_vimage.rs (line 46)
5fn main() {
6    let mut output = vec![0.0_f32; 4];
7    sgemm_row_major(
8        2,
9        2,
10        3,
11        1.0,
12        &[1.0, 2.0, 3.0, 4.0, 5.0, 6.0],
13        &[7.0, 8.0, 9.0, 10.0, 11.0, 12.0],
14        0.0,
15        &mut output,
16    )
17    .expect("sgemm failed");
18    let expected = [58.0_f32, 64.0, 139.0, 154.0];
19    for (actual, expected_value) in output.iter().zip(expected) {
20        assert!(
21            (actual - expected_value).abs() < 1.0e-5,
22            "unexpected sgemm output: {output:?}"
23        );
24    }
25
26    let source_pixels = vec![
27        255_u8, 10, 20, 30, 255, 40, 50, 60, 255, 70, 80, 90, 255, 100, 110, 120,
28    ];
29    let mut src_pixels = source_pixels.clone();
30    let mut rotated_pixels = vec![0_u8; source_pixels.len()];
31    let src = ImageBuffer::from_argb8888(&mut src_pixels, 2, 2).expect("src buffer");
32    let mut rotated =
33        ImageBuffer::from_argb8888(&mut rotated_pixels, 2, 2).expect("rotated buffer");
34    rotate_argb8888(
35        &src,
36        &mut rotated,
37        0.0,
38        [0, 0, 0, 0],
39        vimage_flags::NO_FLAGS,
40    )
41    .expect("rotate failed");
42    assert_eq!(rotated_pixels, source_pixels);
43
44    let mut planar_src = vec![10_u8, 20, 30, 40];
45    let mut planar_dst = vec![0_u8; 4];
46    let planar_src_buffer = ImageBuffer::from_planar8(&mut planar_src, 2, 2).expect("planar src");
47    let mut planar_dst_buffer =
48        ImageBuffer::from_planar8(&mut planar_dst, 2, 2).expect("planar dst");
49    contrast_stretch_planar8(
50        &planar_src_buffer,
51        &mut planar_dst_buffer,
52        vimage_flags::NO_FLAGS,
53    )
54    .expect("contrast stretch failed");
55    assert_eq!(planar_dst, vec![0, 85, 170, 255]);
56
57    println!("blas+vimage smoke passed: sgemm={output:?} contrast={planar_dst:?}");
58}
More examples
Hide additional examples
examples/08_vimage_processing.rs (line 22)
6fn main() {
7    let mut source = vec![255_u8, 10, 20, 30];
8    let mut scaled = vec![0_u8; 16];
9    let src = ImageBuffer::from_argb8888(&mut source, 1, 1).expect("src");
10    let mut dst = ImageBuffer::from_argb8888(&mut scaled, 2, 2).expect("dst");
11    scale_argb8888(&src, &mut dst, vimage_flags::NO_FLAGS).expect("scale");
12    for pixel in scaled.chunks_exact(4) {
13        assert_eq!(pixel, &[255, 10, 20, 30]);
14    }
15
16    let mut interleaved = vec![255_u8, 10, 20, 30, 128, 40, 50, 60];
17    let mut alpha = vec![0_u8; 2];
18    let mut red = vec![0_u8; 2];
19    let mut green = vec![0_u8; 2];
20    let mut blue = vec![0_u8; 2];
21    let src_interleaved = ImageBuffer::from_argb8888(&mut interleaved, 2, 1).expect("src interleaved");
22    let mut alpha_plane = ImageBuffer::from_planar8(&mut alpha, 2, 1).expect("alpha");
23    let mut red_plane = ImageBuffer::from_planar8(&mut red, 2, 1).expect("red");
24    let mut green_plane = ImageBuffer::from_planar8(&mut green, 2, 1).expect("green");
25    let mut blue_plane = ImageBuffer::from_planar8(&mut blue, 2, 1).expect("blue");
26    convert_argb8888_to_planar8(
27        &src_interleaved,
28        &mut alpha_plane,
29        &mut red_plane,
30        &mut green_plane,
31        &mut blue_plane,
32        vimage_flags::NO_FLAGS,
33    )
34    .expect("deinterleave");
35
36    let alpha_plane = ImageBuffer::from_planar8(&mut alpha, 2, 1).expect("alpha src");
37    let red_plane = ImageBuffer::from_planar8(&mut red, 2, 1).expect("red src");
38    let green_plane = ImageBuffer::from_planar8(&mut green, 2, 1).expect("green src");
39    let blue_plane = ImageBuffer::from_planar8(&mut blue, 2, 1).expect("blue src");
40    let mut reinterleaved = vec![0_u8; 8];
41    let mut dst_interleaved = ImageBuffer::from_argb8888(&mut reinterleaved, 2, 1).expect("dst interleaved");
42    convert_planar8_to_argb8888(
43        &alpha_plane,
44        &red_plane,
45        &green_plane,
46        &blue_plane,
47        &mut dst_interleaved,
48        vimage_flags::NO_FLAGS,
49    )
50    .expect("reinterleave");
51    assert_eq!(reinterleaved, interleaved);
52
53    let mut clip_source = vec![64_u8, 100, 50, 10];
54    let mut clip_dest = vec![0_u8; 4];
55    let src_clip = ImageBuffer::from_argb8888(&mut clip_source, 1, 1).expect("clip src");
56    let mut dst_clip = ImageBuffer::from_argb8888(&mut clip_dest, 1, 1).expect("clip dst");
57    clip_to_alpha_argb8888(&src_clip, &mut dst_clip, vimage_flags::NO_FLAGS).expect("clip");
58    assert_eq!(clip_dest, vec![64, 64, 50, 10]);
59
60    let mut planar_src = vec![5_u8, 15, 25, 35];
61    let mut planar_dst = vec![0_u8; 4];
62    let src_planar = ImageBuffer::from_planar8(&mut planar_src, 2, 2).expect("planar src");
63    let mut dst_planar = ImageBuffer::from_planar8(&mut planar_dst, 2, 2).expect("planar dst");
64    contrast_stretch_planar8(&src_planar, &mut dst_planar, vimage_flags::NO_FLAGS)
65        .expect("stretch");
66    assert_eq!(planar_dst, vec![0, 85, 170, 255]);
67
68    println!("vimage smoke passed: scaled={scaled:?} reinterleaved={reinterleaved:?} clipped={clip_dest:?}");
69}

Auto Trait Implementations§

§

impl<'a> Freeze for ImageBuffer<'a>

§

impl<'a> RefUnwindSafe for ImageBuffer<'a>

§

impl<'a> !Send for ImageBuffer<'a>

§

impl<'a> !Sync for ImageBuffer<'a>

§

impl<'a> Unpin for ImageBuffer<'a>

§

impl<'a> UnsafeUnpin for ImageBuffer<'a>

§

impl<'a> !UnwindSafe for ImageBuffer<'a>

Blanket Implementations§

Source§

impl<T> Any for T
where T: 'static + ?Sized,

Source§

fn type_id(&self) -> TypeId

Gets the TypeId of self. Read more
Source§

impl<T> Borrow<T> for T
where T: ?Sized,

Source§

fn borrow(&self) -> &T

Immutably borrows from an owned value. Read more
Source§

impl<T> BorrowMut<T> for T
where T: ?Sized,

Source§

fn borrow_mut(&mut self) -> &mut T

Mutably borrows from an owned value. Read more
Source§

impl<T> From<T> for T

Source§

fn from(t: T) -> T

Returns the argument unchanged.

Source§

impl<T, U> Into<U> for T
where U: From<T>,

Source§

fn into(self) -> U

Calls U::from(self).

That is, this conversion is whatever the implementation of From<T> for U chooses to do.

Source§

impl<T, U> TryFrom<U> for T
where U: Into<T>,

Source§

type Error = Infallible

The type returned in the event of a conversion error.
Source§

fn try_from(value: U) -> Result<T, <T as TryFrom<U>>::Error>

Performs the conversion.
Source§

impl<T, U> TryInto<U> for T
where U: TryFrom<T>,

Source§

type Error = <U as TryFrom<T>>::Error

The type returned in the event of a conversion error.
Source§

fn try_into(self) -> Result<U, <U as TryFrom<T>>::Error>

Performs the conversion.