Adaptive Grid
data:image/s3,"s3://crabby-images/f0bd7/f0bd7470621cb9d9558d8f4dd0297e9db686444b" alt=""
An alternative Grid View for old platforms.
If your minimum deployment target is lower than iOS 16, macOS 11, watchOS 9 or tvOS 16, you may need to use AdaptiveGrid
as to support older platforms.
Otherwise, go ahead and use SwiftUI’s built in Grid
.
- iOS 14.0+
- macOS 11.0+
- tvOS 14.0+
- watchOS 7.0+
Getting Started
It’s similar to SwiftUI’s native Grid
, so you can quickly gettting started.
AdaptiveGrid {
GridRowContainer {
GridCellContainer {
Text("Hello")
}
GridCellContainer {
Image(systemName: "globe")
}
}
GridRowContainer {
GridCellContainer {
Image(systemName: "hand.wave")
}
GridCellContainer {
Text("World")
}
}
}
data:image/s3,"s3://crabby-images/83b39/83b39b796d2a136bfdcd2e8d2d88f309cf9ef4b6" alt=""
You can specify both horizontal and vertical spacing just like how you use the SwiftUI’s native Grid
view.
AdaptiveGrid(horizontalSpacing: 10, verticalSpacing: 10) {
...
}
If you want to add dividers as row seperators, specify showDivider
to true
.
AdaptiveGrid(showDivider: true) {
...
}
Note
Currently, Adaptive Grid takes the maximum space horizontally, which is the same with SwiftUI’s built-in Grid
with Dividers added, so you may need to specify a width
or maxWidth
manually to control the size.
Adaptive Grid
An alternative Grid View for old platforms.
If your minimum deployment target is lower than iOS 16, macOS 11, watchOS 9 or tvOS 16, you may need to use
AdaptiveGrid
as to support older platforms.Otherwise, go ahead and use SwiftUI’s built in
Grid
.Platforms
Getting Started
It’s similar to SwiftUI’s native
Grid
, so you can quickly gettting started.You can specify both horizontal and vertical spacing just like how you use the SwiftUI’s native
Grid
view.If you want to add dividers as row seperators, specify
showDivider
totrue
.Note
Currently, Adaptive Grid takes the maximum space horizontally, which is the same with SwiftUI’s built-in
Grid
with Dividers added, so you may need to specify awidth
ormaxWidth
manually to control the size.