From 8a219e6044084ad0e3494d665c6ff30b4783fb31 Mon Sep 17 00:00:00 2001 From: imgurbot12 Date: Thu, 3 Aug 2023 13:55:15 -0700 Subject: [PATCH] feat: implement image scaling on svg --- rmenu/src/image.rs | 17 +++++++++++------ 1 file changed, 11 insertions(+), 6 deletions(-) diff --git a/rmenu/src/image.rs b/rmenu/src/image.rs index 2d617ac..d6b9c0c 100644 --- a/rmenu/src/image.rs +++ b/rmenu/src/image.rs @@ -18,18 +18,23 @@ enum SvgError { PngError(#[from] png::EncodingError), } -fn svg_to_png(path: &str) -> Result { +fn svg_to_png(path: &str, pixels: u32) -> Result { // read and convert to resvg document tree let xml = read_to_string(path)?; let opt = resvg::usvg::Options::default(); let tree = resvg::usvg::Tree::from_str(&xml, &opt)?; let rtree = resvg::Tree::from_usvg(&tree); - // generate pixel-buffer + // generate pixel-buffer and scale according to size preference let size = rtree.size.to_int_size(); - let mut pixmap = resvg::tiny_skia::Pixmap::new(size.width(), size.height()) - .ok_or_else(|| SvgError::NoPixBuf)?; + let scale = pixels / size.width(); + let width = size.width() * scale; + let height = size.height() * scale; + let fscale = scale as f32; + let mut pixmap = + resvg::tiny_skia::Pixmap::new(width, height).ok_or_else(|| SvgError::NoPixBuf)?; + let form = resvg::tiny_skia::Transform::from_scale(fscale, fscale); // render as png to memory - rtree.render(resvg::tiny_skia::Transform::default(), &mut pixmap.as_mut()); + rtree.render(form, &mut pixmap.as_mut()); let mut png = pixmap.encode_png()?; // base64 encode png let encoded = general_purpose::STANDARD.encode(&mut png); @@ -38,5 +43,5 @@ fn svg_to_png(path: &str) -> Result { #[cached] pub fn convert_svg(path: String) -> Option { - svg_to_png(&path).ok() + svg_to_png(&path, 64).ok() }