In SwiftUI we have two powerful and efficient grids to display multiple items:
- LazyVGrid
- LazyHGrid
The fundamental element for these types of grids is the GridItem, which can be of three types:
- .adaptive
- .fixed
- .flexible
GridItem Adaptive
GridItem Adaptive is essential for a responsive layout. By setting a minimum size for it, the grid will try to adapt to all the available space.
Take a look at using LazyHGrid:
struct ContentView: View {
let rainbowColors = [Color.red, Color.orange, Color.yellow, Color.green, Color.mint, Color.teal, Color.cyan, Color.blue, Color.indigo, Color.purple, Color.brown]
var body: some View {
ScrollView(.horizontal) {
LazyHGrid(rows: [GridItem(.adaptive(minimum:150))]) {
ForEach(rainbowColors, id:\.self) { color in
Circle()
.fill(color)
}
}
.padding()
}
}
}
data:image/s3,"s3://crabby-images/da59e/da59ee27004ca5289f7bb5f8d0f783a847a97930" alt=""
We can also define different sizes for the rows:
ScrollView(.horizontal) {
LazyHGrid(rows: [GridItem(.adaptive(minimum:150)),GridItem(.adaptive(minimum:100))]) {
ForEach(rainbowColors, id:\.self) { color in
Circle().fill(color)
}
}
.padding()
}
So we have:
data:image/s3,"s3://crabby-images/1c896/1c8969dd38d62647bf7432d07d9b8e2310d505a0" alt=""
So, the two different dimensions are used to adapt to the screen.
This type is helpful when we have a dynamic number of elements, such as in a playlist.
Using the Vertical grid:
ScrollView() {
LazyVGrid(columns: [GridItem(.adaptive(minimum:100)), GridItem(.adaptive(minimum:50)),GridItem(.adaptive(minimum:100))]) {
ForEach(rainbowColors, id:\.self) { color in
Circle()
.fill(color)
}
}
.padding()
}
}
data:image/s3,"s3://crabby-images/79195/79195d9ac0831f1dec8ce08ad53cb72b40743511" alt=""
GridItem Fixed
In this case, the GridItem has a fixed size for the horizontal layout:
ScrollView(.horizontal) {
LazyHGrid(rows: [GridItem(.fixed(100))]) {
ForEach(rainbowColors, id:\.self) { color in
Circle()
.fill(color)
}
}
.padding()
}
data:image/s3,"s3://crabby-images/18dac/18dac867b5edcdfb6a0b782bc225edc8dd3bc0f8" alt=""
For vertical:
ScrollView() {
LazyVGrid(columns: [GridItem(.fixed(100))]) {
ForEach(rainbowColors, id:\.self) { color in
Circle()
.fill(color)
}
}
.padding()
}
}
data:image/s3,"s3://crabby-images/1ba88/1ba886d1c0927ee5125e5abebe137d280241f395" alt=""
This is helpful when you need a fixed number of columns or rows. In this case, by adding GridItem with a fixed size, we don’t have adaptability to the screen.
Take a look at this example:
ScrollView() {
LazyVGrid(columns: [GridItem(.fixed(150)),GridItem(.fixed(150)),GridItem(.fixed(150))]) {
ForEach(rainbowColors, id:\.self) { color in
Circle()
.fill(color)
}
}
.padding()
}
We have:
data:image/s3,"s3://crabby-images/5054f/5054ff5357e86c1ac539ac59d04073b51fae33db" alt=""
Three columns of circles with fixed size but truncated.
GridItem Flexible
With flexible, we define the size of GridItem within a range. For example:
ScrollView(.horizontal) {
LazyHGrid(rows: [GridItem(.flexible(minimum: 10, maximum: 50)),GridItem(.flexible(minimum: 20, maximum: 100))]) {
ForEach(rainbowColors, id:\.self) { color in
Circle()
.fill(color)
}
}
.padding()
}
To have:
data:image/s3,"s3://crabby-images/99bd1/99bd1465d404a2bda181c031343be8948d5efd72" alt=""
It’s helpful when we need different sizes for different content, such as images and text.
Leave a Reply