Today I will show you how to use the rotate and offset functions to mirror a view.
Steps:
First, import an image with half the portrait.
data:image/s3,"s3://crabby-images/2b5f4/2b5f497b693432167168f4855e4457a209ef3866" alt=""
Then add a ZStack as a container for the subviews.
Add an Image and load the image resource with half of the portrait.
ZStack {
Image("fox-half")
}
data:image/s3,"s3://crabby-images/60f06/60f0680df0d09e4c725770e6bd117a466f6341bf" alt=""
Add another same Image.
Rotate the Image 180 degrees in the horizontal direction.
Image("fox-half")
.rotation3DEffect(.degrees(180), axis: (x: 1, y: 0, z: 0))
data:image/s3,"s3://crabby-images/9a1d8/9a1d86eab128b0b58995b9e189ce70eaed239c59" alt=""
Then rotate the Image 180 degrees in the vertical direction.
.rotationEffect(.degrees(180), anchor: .center)
data:image/s3,"s3://crabby-images/57aee/57aee92b7a9c7cf6a99f3716e333ae02f8a6667e" alt=""
Offset the Image horizontally to the right.
.offset(x: 160, y: 0)
data:image/s3,"s3://crabby-images/62d02/62d026f8a35408a383be860a0392367e2429153d" alt=""
Finally, move the ZStack to the left so that the entire frame is in the center of the screen.
.offset(x: -80, y: 0)
data:image/s3,"s3://crabby-images/5a72b/5a72bcf48c19ec245a8419c38b382bbb5b19caf1" alt=""
Source Code:
struct ContentView: View {
var body: some View {
ZStack {
Image("fox-half")
Image("fox-half")
.rotation3DEffect(.degrees(180), axis: (x: 1, y: 0, z: 0))
.rotationEffect(.degrees(180), anchor: .center)
.offset(x: 160, y: 0)
}
.offset(x: -80, y: 0)
}
}
Follow me on:
Comments