use crate::image_crate::{load_from_memory, open, DynamicImage, ImageBuffer};
use std::path::Path;
pub use self::modifiers::*;
use crate::transformer::TransformerError;
use crate::{Set, Transformer};
pub mod modifiers;
#[allow(missing_debug_implementations)]
pub struct Image {
value: DynamicImage,
}
impl Set for Image {}
impl Transformer for Image {
fn transform_to_vec(&self) -> Vec<f32> {
self.value.to_bytes().iter().map(|&e| e as f32).collect()
}
}
impl Image {
pub fn new(image: DynamicImage) -> Image {
Image { value: image }
}
pub fn from_path<P>(path: P) -> Image
where
P: AsRef<Path>,
{
Image {
value: open(path).unwrap(),
}
}
pub fn from_buffer(buf: &[u8]) -> Image {
Image {
value: load_from_memory(buf).unwrap(),
}
}
pub fn from_rgb_pixels(w: u32, h: u32, buf: Vec<u8>) -> Result<Image, TransformerError> {
let dynamic_image = ImageBuffer::from_raw(w, h, buf).map(DynamicImage::ImageRgb8);
match dynamic_image {
Some(image) => Ok(Image { value: image }),
None => Err(TransformerError::InvalidRgbPixels),
}
}
pub fn from_rgba_pixels(w: u32, h: u32, buf: Vec<u8>) -> Result<Image, TransformerError> {
let dynamic_image = ImageBuffer::from_raw(w, h, buf).map(DynamicImage::ImageRgba8);
match dynamic_image {
Some(image) => Ok(Image { value: image }),
None => Err(TransformerError::InvalidRgbaPixels),
}
}
pub fn from_luma_pixels(w: u32, h: u32, buf: Vec<u8>) -> Result<Image, TransformerError> {
let dynamic_image = ImageBuffer::from_raw(w, h, buf).map(DynamicImage::ImageLuma8);
match dynamic_image {
Some(image) => Ok(Image { value: image }),
None => Err(TransformerError::InvalidLumaPixels),
}
}
pub fn from_lumaa_pixels(w: u32, h: u32, buf: Vec<u8>) -> Result<Image, TransformerError> {
let dynamic_image = ImageBuffer::from_raw(w, h, buf).map(DynamicImage::ImageLumaA8);
match dynamic_image {
Some(image) => Ok(Image { value: image }),
None => Err(TransformerError::InvalidLumaAlphaPixels),
}
}
}