-
Notifications
You must be signed in to change notification settings - Fork 83
Getting started
The root entity here is SVGView class. It is a descendant of the View class so you can include it into your body code. Inside it contains svg
field of class SVGNode
, which is a base class for all the nodes - shapes, text, images and groups. Groups contain more nodes inside them. Using all these we create a hierarchy of nodes, representing the whole svg structure. svg
field is an observable - meaning you can make all the necessary adjusments using this field, and displayed picture will change on the fly.
To construct SVGView and nodes inside it DOMParser
and SVGParser
are used. DOMParser
creates a tree af xmlNodes from svg file, and SVGParser
makesa tree SVGNodes from it. Some svg nodes may contain links. Those links are relative to svg file's location. So SVGParser
holds this path for internal usage.
Let's take this simple svg file as an example and parse it with our library.
<svg height="150" width="500" xmlns="http://www.w3.org/2000/svg"
xmlns:xlink="http://www.w3.org/1999/xlink">
<ellipse cx="240" cy="100" rx="220" ry="30" fill="purple" id="first"/>
<ellipse cx="220" cy="70" rx="190" ry="20" fill="lime" />
<ellipse cx="210" cy="45" rx="170" ry="15" fill="yellow" />
</svg>
You can create SVGView with 3 constructors. Here is their usage and some examples of what you can do with their result: a. Passing your svg file URL:
let fileURL = Bundle.main.url(forResource: "example", withExtension: "svg")!
var body: some View {
let root = SVGView(fileURL: fileURL) // 1
let first = root.svg.nodeById("first") // 2
first?.onTap = { // 3
(first as? SVGShape)?.fill = SVGColor.by(name: "red") // 4
}
return root
}
1 - By passing this URL here you also set it to parser's context (I explained parser's context in structure section) 2 - locate any node in the hierarchy by its id (id is a field you can add to any node inside svg file, like I did in svg example above) 3 - onTap can be attached to any node (there will be more gestures in the future) 4 - change first ellipse's fill color to red on tap
b. Passing a node - manually constructed or received as result of another SVGView pasring:
var body: some View {
let node = SVGCircle(cx: 40, cy: 40, r: 30)
node.fill = SVGColor.by(name: "red")
return SVGView(svg: node) // 1
}
1 - or you can write return node.toSwiftUI()
c. Passing raw xml representation of your svg:
var body: some View {
let xml = DOMParser.parse(fileURL: fileURL)
xml.attributes["opacity"] = "0.5" // 1
return SVGView(xml: xml)
}
1 - this way you can edit xml attributes and structure directly, like you would by editing the svg file itself. Just be carefull with your spelling)
You can choose to use SVGParse
directly - without SVGView
var body: some View {
let node = SVGParser.parse(fileURL: fileURL)
return node.toSwiftUI()
}
node is what root.svg used to be in SVGView
You can also pass xml:
var body: some View {
let xml = DOMParser.parse(fileURL: fileURL)
let node = SVGParser.parse(xml: xml, fileURL: fileURL)
return node.toSwiftUI()
}
Notice that here we also pass fileURL to SVGParser
, though it will not use the file itself - all the file parsing was done by DOMParser
. We pass it so that SVGParser
has the context fro figuring out relative fiel links, which might come up in svg.
There are 4 node types - shapes, text, images and groups.
- Shape. SVG has these types of shapes: circle, ellipse, line, path, polygon, polyline, rect. You can see some examples in constructors section. For more info check out svg documentation for each type, our nodes just repeat their structure.
- Text
let node = SVGText(text: "Example")
node.fill = SVGColor.by(name: "red")
node.font = SVGFont(name: "Arial Bold Italic", size: 27)
fill, font and any other parameter can also be passed as constructor arguments
- Image. There are two types of images supported by SVGView: url and data:
- SVGURLImage takes an url path to image file (jpeg or png) relative to svg file itself. It will only work you passed fileURL to parse in order to construct you svgNode (see above for options to pass it)
- SVGDataImage takes Data containing base64Encoded encoded image
- Group. Just contains an array of child nodes.