use image::*;
use std::{env::args, fmt::format, path::Path};
use webp::*;
fn main() {
let arg: Vec<String> = args().collect();
if arg.len() != 2 {
eprintln!("Usage: command <name.extension>");
return;
}
let path = format(format_args!("assets/{}", arg[1]));
let path = Path::new(&path);
let img = image::open(path).unwrap();
let (w, h) = img.dimensions();
let size_factor = 1.0;
let img: DynamicImage = image::DynamicImage::ImageRgba8(imageops::resize(
&img,
(w as f64 * size_factor) as u32,
(h as f64 * size_factor) as u32,
imageops::FilterType::Triangle,
));
let encoder: Encoder = Encoder::from_image(&img).unwrap();
let webp: WebPMemory = encoder.encode(90f32);
let output_path = Path::new("assets").join("lake").with_extension("webp");
std::fs::write(&output_path, &*webp).unwrap();
}
#[test]
fn test_convert() {
let path = format(format_args!("assets/{}", "lake.jpg"));
let path = Path::new(&path);
let img = image::open(path).unwrap();
let (w, h) = img.dimensions();
let size_factor = 1.0;
let img: DynamicImage = image::DynamicImage::ImageRgba8(imageops::resize(
&img,
(w as f64 * size_factor) as u32,
(h as f64 * size_factor) as u32,
imageops::FilterType::Triangle,
));
let encoder: Encoder = Encoder::from_image(&img).unwrap();
let webp: WebPMemory = encoder.encode(90f32);
let output_path = Path::new("assets").join("lake").with_extension("webp");
std::fs::write(&output_path, &*webp).unwrap();
}