Stack in SwiftUI
In previous post we have used Stack but i have not explained it there.
SwiftUI allows us to add nested Stacks too means you can have a HStack inside a VStack or vice-versa or any other combinations.
SwiftUI has categorized Stack into 3 types:
1. HStack - Horizontal Stack
2. VStack - Vertical Stack
3. ZStack - Z Index Stack
1. HStack - If you want to place UI horizontally use this type.
Code Snipped:
Explanation - Here i have created a HStack and added two Color's namely red and blue.
Now you would like to ask me how you can add a Color instead of a View!!!
So in SwiftUI we can treat Color also as a View, let me elaborate it.
It will draw a View within a provided space by the HStack and fill it with the provided Color and returns it as a View.
Output of Code Snippet:
data:image/s3,"s3://crabby-images/d8f28/d8f28f47616707a8ec30ae6edcf9ef0579278b02" alt=""
2. VStack - This will add a Vertical Stack to your View.
Code Snippet:
Explanation - Similar to HStack here we have the VStack it will place the items in Vertical manner. Red color on top and blue color on bottom.
Output of Code Snippet:
data:image/s3,"s3://crabby-images/48b47/48b47eda61d9ffc04216c51326a7131bbfdd16e4" alt=""
3. ZStack - If you want to place items one above another this is the one you can use.
Code Snippet:
Explanation -
Sometimes we need to place some item above other, like a Text on Image. So here we have a ZStack here to make it simple. I have placed a Text above the Color.
Output of Code Snippet:
data:image/s3,"s3://crabby-images/d6109/d610989c9e5e79442f25efdf496fd9b273bddca8" alt=""
Here is a code snippet for nested Stack:
Explanation - I have added a VStack inside HStack, so the left side will have two Color Views red and green.
Output of Code Snipped:
data:image/s3,"s3://crabby-images/527ca/527ca60d02a6738244921dcfd0c67ecdc748018a" alt=""
SwiftUI allows us to add nested Stacks too means you can have a HStack inside a VStack or vice-versa or any other combinations.
SwiftUI has categorized Stack into 3 types:
1. HStack - Horizontal Stack
2. VStack - Vertical Stack
3. ZStack - Z Index Stack
1. HStack - If you want to place UI horizontally use this type.
Code Snipped:
struct ContentView: View {
var body: some View {
HStack {
Color(.red)
Color(.blue)
}
}
}
Explanation - Here i have created a HStack and added two Color's namely red and blue.
Now you would like to ask me how you can add a Color instead of a View!!!
So in SwiftUI we can treat Color also as a View, let me elaborate it.
It will draw a View within a provided space by the HStack and fill it with the provided Color and returns it as a View.
Output of Code Snippet:
data:image/s3,"s3://crabby-images/d8f28/d8f28f47616707a8ec30ae6edcf9ef0579278b02" alt=""
2. VStack - This will add a Vertical Stack to your View.
Code Snippet:
struct ContentView: View {
var body: some View {
VStack {
Color(.red)
Color(.blue)
}
}
}
Explanation - Similar to HStack here we have the VStack it will place the items in Vertical manner. Red color on top and blue color on bottom.
Output of Code Snippet:
data:image/s3,"s3://crabby-images/48b47/48b47eda61d9ffc04216c51326a7131bbfdd16e4" alt=""
3. ZStack - If you want to place items one above another this is the one you can use.
Code Snippet:
struct ContentView: View {
var body: some View {
ZStack {
Color(.red)
Text("This is On the Top of Red Color View")
.foregroundColor(.white)
}
}
}
Explanation -
Sometimes we need to place some item above other, like a Text on Image. So here we have a ZStack here to make it simple. I have placed a Text above the Color.
Output of Code Snippet:
data:image/s3,"s3://crabby-images/d6109/d610989c9e5e79442f25efdf496fd9b273bddca8" alt=""
Here is a code snippet for nested Stack:
struct ContentView: View {
var body: some View {
HStack {
VStack {
Color(.red)
Color(.green)
}
Color(.blue)
}
}
}
Explanation - I have added a VStack inside HStack, so the left side will have two Color Views red and green.
Output of Code Snipped:
data:image/s3,"s3://crabby-images/527ca/527ca60d02a6738244921dcfd0c67ecdc748018a" alt=""
Comments
Post a Comment