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
31
32
33
34
35
36
37
38
39
40
41
use image::{DynamicImage, GenericImageView, ImageBuffer, Rgba};
pub fn masked_cut(image: &DynamicImage, mask: &DynamicImage) -> ImageBuffer<Rgba<u8>, Vec<u8>> {
let mut img = image.to_rgba8();
let (width, height) = img.dimensions();
let (mwidth, mheight) = mask.dimensions();
let wrate = mwidth as f64 / width as f64;
let hrate = mheight as f64 / height as f64;
for x in 0..width {
for y in 0..height {
let mut px = *img.get_pixel(x, y);
let alpha = mask.get_pixel((x as f64 * wrate) as u32, (y as f64 * hrate) as u32);
let avg = 255 - ((alpha.0[0] as u32 + alpha.0[1] as u32 + alpha.0[2] as u32) / 3) as u8;
px.0[3] = avg;
img.put_pixel(x, y, px);
}
}
img
}
#[cfg(test)]
mod tests {
use super::*;
#[test]
fn it_works() {
let image = image::open("cat.jpg").unwrap();
let mask = image::open("mask_4k.png").unwrap();
masked_cut(&image, &mask).save("test.png").unwrap();
}
}