Today I will show you how to use Path.
Path can draw highly complex graphics, and I'm just showing its basic functions here.
Steps:
First, add a Path, define the Path shape in the closure
Move the coordinates of Path to {50, 0}
Draw a line from the starting point of Path through the addLine method to {50, 200}
Then draw a line to the right from {50, 200} to {250, 200}
var body: some View {
Path { path in
path.move(to: CGPoint(x: 50, y: 0))
path.addLine(to: CGPoint(x: 50, y: 200))
path.addLine(to: CGPoint(x: 250, y: 200))
}
}
data:image/s3,"s3://crabby-images/4fe7f/4fe7f537283ebae270050a5432eff96c74f5cc61" alt=""
Continue to draw a straight line upwards to {250, 0}
This way, we get a square Path of size 250x250.
path.addLine(to: CGPoint(x: 250, y: 0))
data:image/s3,"s3://crabby-images/8724a/8724addae71faa21146c77fd0613916da0441ec2" alt=""
Then draw another Path and move the new starting point to {50, 300}
Then use addQuadCurve to draw a Bezier curve to {250, 300}, control point to {150, 450}
Add another Bezier curve in the same way to {350, 300}, control point to {300, 220}
path.move(to: CGPoint(x: 50, y: 300))
path.addQuadCurve(to: CGPoint(x: 250, y: 300),
control: CGPoint(x: 150, y: 450))
path.addQuadCurve(to: CGPoint(x: 350, y: 300),
control: CGPoint(x: 300, y: 220))
data:image/s3,"s3://crabby-images/3785d/3785dd3387e0b0d7bfb387c0a091e3ab4b7b6d7d" alt=""
Then add a stroke effect to the Path and set the lineWidth to 8. In this case, the fill color of all paths will disappear.
.stroke(lineWidth: 8)
data:image/s3,"s3://crabby-images/3d19d/3d19d86dd5185a09af30e9975b91db8b69e1b098" alt=""
data:image/s3,"s3://crabby-images/56e93/56e9346753a4ae3d18e7b903a2fb714e3fc85a41" alt=""
In addition to using Path to draw straight lines or curves, you can also use Path to draw typical graphics such as ellipses and rectangles.
Add a new Path.
Use addEllipse to draw an ellipse/circle, parameters: x: 90, y: 50, width: 200, height: 200
path.addEllipse(in: CGRect(x: 90, y: 50, width: 200, height: 200))
data:image/s3,"s3://crabby-images/53a30/53a30e69f1f12dcc7df2ba498f2cffad60a8a96b" alt=""
Use addRoundedRect to draw a rectangle with rounded corners.
path.addRoundedRect(in: CGRect(x: 90, y: 50, width: 200, height: 200), cornerSize: CGSize(width: 32, height: 32))
data:image/s3,"s3://crabby-images/d6f86/d6f86367f7053247db1df2d55b6ee5904f1b6339" alt=""
Follow me on:
Comments