Today I will show you how to use Rectangle and RoundedRectangle.
Steps:
First, draw a simple Rectangle with a default fill color of black.
Rectangle()
data:image/s3,"s3://crabby-images/ec166/ec166e0be820c24cf0fe6ac2c2ba415310f14002" alt=""
Change its color to yellow and set its width and height.
Rectangle()
.fill(.yellow)
.frame(width: 200, height: 200)
data:image/s3,"s3://crabby-images/f69d6/f69d63034d32b3aa8d7cc3299a6d9512f524de2c" alt=""
Then, create a set of overlapping rectangles.
Add a ZStack as a container for the subviews.
Draw a rectangle and set its fill color to blue.
Set its width and height.
ZStack {
Rectangle()
.fill(.blue)
.frame(width: 300, height: 300)
}
data:image/s3,"s3://crabby-images/3a4fe/3a4fe196879fbdfd2f442e8040d843c536996e12" alt=""
Then draw a second yellow rectangle and make it 0.8 times smaller.
Finally, in the same way, draw a third red rectangle and make it 0.6 times smaller.
This way, we have completed the drawing of the three overlapping rectangles.
ZStack {
Rectangle()
.fill(.blue)
.frame(width: 300, height: 300)
Rectangle()
.fill(.yellow)
.frame(width: 300, height: 300)
.scaleEffect(0.8)
Rectangle()
.fill(.red)
.frame(width: 300, height: 300)
.scaleEffect(0.6)
}
data:image/s3,"s3://crabby-images/7d48b/7d48b796ded438a40ed67eb9ecccfc84281119f1" alt=""
Next, draw a RoundedRectangle and set its corner radius to 120.
Sets the rounded corners' width and height.
RoundedRectangle(cornerSize: CGSize(width: 60, height: 60))
.frame(width: 300, height: 200)
data:image/s3,"s3://crabby-images/898d8/898d8cca88366d566ec980ae553aa3029f5b8b51" alt=""
Draw a RoundedRectangle with a corner radius of 60.
Set the rounded corner style to .continuous, which means rounded corners with continuous curvature.
RoundedRectangle(cornerRadius: 60, style: .continuous)
data:image/s3,"s3://crabby-images/f265d/f265d23f62642c6e020f3bca97f52e7a0ff99f8f" alt=""
Add a stroke to the RoundedRectangle and set the stroke width to 20.
RoundedRectangle(cornerRadius: 60, style: .continuous)
.stroke(lineWidth: 20)
data:image/s3,"s3://crabby-images/c8028/c80289ed1c78be9e5edd4218d76864f128da9996" alt=""
Source and final effect:
import SwiftUI
struct ContentView: View {
var body: some View {
VStack {
Rectangle()
.fill(.yellow)
.frame(width: 100, height: 100)
ZStack {
Rectangle()
.fill(.blue)
.frame(width: 150, height: 150)
Rectangle()
.fill(.yellow)
.frame(width: 150, height: 150)
.scaleEffect(0.8)
Rectangle()
.fill(.red)
.frame(width: 150, height: 150)
.scaleEffect(0.6)
}
RoundedRectangle(cornerSize: CGSize(width: 30, height: 30))
.frame(width: 150, height: 100)
RoundedRectangle(cornerRadius: 30, style: .continuous)
.stroke(lineWidth: 20)
.padding()
}
.padding()
}
}
data:image/s3,"s3://crabby-images/0a808/0a80887e2ced045b4362275ee9526ea20c5c8d24" alt=""
Follow me on:
Comments