mirror of
https://github.com/slint-ui/slint.git
synced 2025-10-01 06:11:16 +00:00
39 lines
1.6 KiB
Rust
39 lines
1.6 KiB
Rust
/* LICENSE BEGIN
|
|
This file is part of the SixtyFPS Project -- https://sixtyfps.io
|
|
Copyright (c) 2020 Olivier Goffart <olivier.goffart@sixtyfps.io>
|
|
Copyright (c) 2020 Simon Hausmann <simon.hausmann@sixtyfps.io>
|
|
|
|
SPDX-License-Identifier: GPL-3.0-only
|
|
This file is also available under commercial licensing terms.
|
|
Please contact info@sixtyfps.io for more information.
|
|
LICENSE END */
|
|
#![cfg(feature = "svg")]
|
|
|
|
#[cfg(not(target_arch = "wasm32"))]
|
|
pub fn load_from_path(path: &std::path::Path) -> Result<usvg::Tree, usvg::Error> {
|
|
usvg::Tree::from_file(path, &Default::default())
|
|
}
|
|
|
|
pub fn load_from_data(slice: &[u8]) -> Result<usvg::Tree, usvg::Error> {
|
|
usvg::Tree::from_data(slice, &Default::default())
|
|
}
|
|
|
|
pub fn render(
|
|
tree: &usvg::Tree,
|
|
size: euclid::default::Size2D<u32>,
|
|
) -> Result<image::DynamicImage, usvg::Error> {
|
|
// resvg doesn't support scaling to width/height, just fit to width.
|
|
// FIXME: the fit should actually depends on the image-fit property
|
|
let fit = usvg::FitTo::Width(size.width);
|
|
let size = fit.fit_to(tree.svg_node().size.to_screen_size()).ok_or(usvg::Error::InvalidSize)?;
|
|
let mut buffer =
|
|
vec![0u8; size.width() as usize * size.height() as usize * tiny_skia::BYTES_PER_PIXEL];
|
|
let skya_buffer =
|
|
tiny_skia::PixmapMut::from_bytes(buffer.as_mut_slice(), size.width(), size.height())
|
|
.ok_or(usvg::Error::InvalidSize)?;
|
|
resvg::render(&tree, fit, skya_buffer).ok_or(usvg::Error::InvalidSize)?;
|
|
Ok(image::DynamicImage::ImageRgba8(
|
|
image::RgbaImage::from_raw(size.width(), size.height(), buffer)
|
|
.ok_or(usvg::Error::InvalidSize)?,
|
|
))
|
|
}
|