43 breaking releases

0.44.0 Sep 28, 2024
0.42.0 Jun 1, 2024
0.40.0 Feb 17, 2024
0.37.0 Dec 16, 2023
0.2.0 May 23, 2018

#180 in Images

Download history 51183/week @ 2024-09-27 50540/week @ 2024-10-04 48331/week @ 2024-10-11 56837/week @ 2024-10-18 56909/week @ 2024-10-25 63847/week @ 2024-11-01 49405/week @ 2024-11-08 52175/week @ 2024-11-15 56607/week @ 2024-11-22 61402/week @ 2024-11-29 62615/week @ 2024-12-06 63660/week @ 2024-12-13 36876/week @ 2024-12-20 37016/week @ 2024-12-27 60560/week @ 2025-01-03 60680/week @ 2025-01-10

204,983 downloads per month
Used in 378 crates (105 directly)

MPL-2.0 license

590KB
14K SLoC

usvg

Crates.io Documentation Rust 1.65+

usvg (micro SVG) is an SVG parser that tries to solve most of SVG complexity.

SVG is notoriously hard to parse. usvg presents a layer between an XML library and a potential SVG rendering library. It will parse an input SVG into a strongly-typed tree structure were all the elements, attributes, references and other SVG features are already resolved and presented in the simplest way possible. So a caller doesn't have to worry about most of the issues related to SVG parsing and can focus just on the rendering part.

Features

  • All supported attributes are resolved. No need to worry about inheritable, implicit and default attributes
  • CSS will be applied
  • Only simple paths
    • Basic shapes (like rect and circle) will be converted into paths
    • Paths contain only absolute MoveTo, LineTo, QuadTo, CurveTo and ClosePath segments. ArcTo, implicit and relative segments will be converted
  • use will be resolved and replaced with the reference content
  • Nested svg will be resolved
  • Invalid, malformed elements will be removed
  • Relative length units (mm, em, etc.) will be converted into pixels/points
  • External images will be loaded
  • Internal, base64 images will be decoded
  • All references (like #elem and url(#elem)) will be resolved
  • switch will be resolved
  • Text elements, which are probably the hardest part of SVG, will be completely resolved. This includes all the attributes resolving, whitespaces preprocessing (xml:space), text chunks and spans resolving
  • Markers will be converted into regular elements. No need to place them manually
  • All filters are supported. Including filter functions, like filter="contrast(50%)"
  • Recursive elements will be detected and removed
  • objectBoundingBox will be replaced with userSpaceOnUse

Limitations

  • Unsupported SVG features will be ignored
  • CSS support is minimal
  • Only static SVG features, e.g. no a, view, cursor, script, no events and no animations

License

usvg is licensed under the MPLv2.0.

Dependencies

~2.2–3.5MB
~65K SLoC