mirror of
https://github.com/imgurbot12/rmenu.git
synced 2025-01-13 07:46:24 +01:00
feat: implement image scaling on svg
This commit is contained in:
parent
a14ce28167
commit
8a219e6044
1 changed files with 11 additions and 6 deletions
|
@ -18,18 +18,23 @@ enum SvgError {
|
||||||
PngError(#[from] png::EncodingError),
|
PngError(#[from] png::EncodingError),
|
||||||
}
|
}
|
||||||
|
|
||||||
fn svg_to_png(path: &str) -> Result<String, SvgError> {
|
fn svg_to_png(path: &str, pixels: u32) -> Result<String, SvgError> {
|
||||||
// read and convert to resvg document tree
|
// read and convert to resvg document tree
|
||||||
let xml = read_to_string(path)?;
|
let xml = read_to_string(path)?;
|
||||||
let opt = resvg::usvg::Options::default();
|
let opt = resvg::usvg::Options::default();
|
||||||
let tree = resvg::usvg::Tree::from_str(&xml, &opt)?;
|
let tree = resvg::usvg::Tree::from_str(&xml, &opt)?;
|
||||||
let rtree = resvg::Tree::from_usvg(&tree);
|
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 size = rtree.size.to_int_size();
|
||||||
let mut pixmap = resvg::tiny_skia::Pixmap::new(size.width(), size.height())
|
let scale = pixels / size.width();
|
||||||
.ok_or_else(|| SvgError::NoPixBuf)?;
|
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
|
// 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()?;
|
let mut png = pixmap.encode_png()?;
|
||||||
// base64 encode png
|
// base64 encode png
|
||||||
let encoded = general_purpose::STANDARD.encode(&mut png);
|
let encoded = general_purpose::STANDARD.encode(&mut png);
|
||||||
|
@ -38,5 +43,5 @@ fn svg_to_png(path: &str) -> Result<String, SvgError> {
|
||||||
|
|
||||||
#[cached]
|
#[cached]
|
||||||
pub fn convert_svg(path: String) -> Option<String> {
|
pub fn convert_svg(path: String) -> Option<String> {
|
||||||
svg_to_png(&path).ok()
|
svg_to_png(&path, 64).ok()
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in a new issue