Merge pull request #292 from msiglreith/svg-transform

vello_svg: Use affine transformation
This commit is contained in:
Markus Siglreithmaier 2023-03-10 12:36:39 +01:00 committed by GitHub
commit dccd59a217
No known key found for this signature in database
GPG key ID: 4AEE18F83AFDEB23

View file

@ -64,7 +64,10 @@ pub fn render_tree_with<F: FnMut(&mut SceneBuilder, &usvg::Node) -> Result<(), E
mut on_err: F, mut on_err: F,
) -> Result<(), E> { ) -> Result<(), E> {
for elt in svg.root.descendants() { for elt in svg.root.descendants() {
let transform = elt.abs_transform(); let transform = {
let usvg::Transform { a, b, c, d, e, f } = elt.abs_transform();
Affine::new([a, b, c, d, e, f])
};
match &*elt.borrow() { match &*elt.borrow() {
usvg::NodeKind::Group(_) => {} usvg::NodeKind::Group(_) => {}
usvg::NodeKind::Path(path) => { usvg::NodeKind::Path(path) => {
@ -72,7 +75,7 @@ pub fn render_tree_with<F: FnMut(&mut SceneBuilder, &usvg::Node) -> Result<(), E
// The semantics of SVG paths don't line up with `BezPath`; we must manually track initial points // The semantics of SVG paths don't line up with `BezPath`; we must manually track initial points
let mut just_closed = false; let mut just_closed = false;
let mut most_recent_initial = (0., 0.); let mut most_recent_initial = (0., 0.);
for elt in usvg::TransformedPath::new(&path.data, transform) { for elt in path.data.segments() {
match elt { match elt {
usvg::PathSegment::MoveTo { x, y } => { usvg::PathSegment::MoveTo { x, y } => {
if std::mem::take(&mut just_closed) { if std::mem::take(&mut just_closed) {
@ -112,7 +115,7 @@ pub fn render_tree_with<F: FnMut(&mut SceneBuilder, &usvg::Node) -> Result<(), E
if let Some(fill) = &path.fill { if let Some(fill) = &path.fill {
if let Some(brush) = paint_to_brush(&fill.paint, fill.opacity) { if let Some(brush) = paint_to_brush(&fill.paint, fill.opacity) {
// FIXME: Set the fill rule // FIXME: Set the fill rule
sb.fill(Fill::NonZero, Affine::IDENTITY, &brush, None, &local_path); sb.fill(Fill::NonZero, transform, &brush, None, &local_path);
} else { } else {
on_err(sb, &elt)?; on_err(sb, &elt)?;
} }
@ -122,7 +125,7 @@ pub fn render_tree_with<F: FnMut(&mut SceneBuilder, &usvg::Node) -> Result<(), E
// FIXME: handle stroke options such as linecap, linejoin, etc. // FIXME: handle stroke options such as linecap, linejoin, etc.
sb.stroke( sb.stroke(
&Stroke::new(stroke.width.get() as f32), &Stroke::new(stroke.width.get() as f32),
Affine::IDENTITY, transform,
&brush, &brush,
None, None,
&local_path, &local_path,