Using scroll views
SwiftUI scroll views are used to easily create scrolling containers. They automatically size themselves to the area where they are placed. Scroll views are vertical by default and can be made to scroll horizontally or vertically by passing in the .horizontal() or .vertical() modifiers as the first parameter to the scroll view.
Getting ready
Let's start by creating a SwiftUI project called ScrollViewApp.
Optional: Download the San Francisco (SF) Symbols app here: https://developer.apple.com/sf-symbols/.
SF Symbols is a set of over 2,400 symbols provided by Apple. They follow Apple's San Francisco system font and automatically ensure optical vertical alignment for different sizes and weights.
How to do it…
We will add two scroll views to a VStack component: one horizontal and one vertical. Each scroll view will contain SF symbols for the letters A–L:
- Between the
ContentViewstruct declaration and its body, create an array of SF symbol names calledimageNames. Add the strings for SF symbols A–L:let imageNames = [ "a.circle.fill", "b.circle.fill", "c.circle.fill", "d.circle.fill", "e.circle.fill", "f.circle.fill", "g.circle.fill", "h.circle.fill", "i.circle.fill", "j.circle.fill", "k.circle.fill", "l.circle.fill", ]
- Add a
VStackcomponent and scroll views to the app:var body: some View { VStack{ ScrollView { ForEach(self.imageNames, id: \.self) { name in Image(systemName: name) .font(.largeTitle) .foregroundColor(Color. yellow) .frame(width: 50, height: 50) .background(Color.blue) } } .frame(width:50, height:200) ScrollView(.horizontal, showsIndicators: false) { HStack{ ForEach(self.imageNames, id: \.self) { name in Image(systemName: name) .font(.largeTitle) .foregroundColor(Color. yellow) .frame(width: 50, height: 50) .background(Color.blue) } } } } }The result is a view with a vertical and horizontal scroll view:
Figure 2.1 – App with horizontal and vertical scroll views
How it works…
VStack allows us to display multiple scroll views within the ContentView struct's body.
By default, scroll views display items vertically. The first ScrollView component in VStack displays items in a vertical way, even though no axis was specified.
Within the first ScrollView component, a ForEach loop is used to iterate over a static array and display the contents. In this case, the ForEach loop takes two parameters: the array we are iterating over and an identifier, id: \.self, used to distinguish between the items being displayed. The id parameter would not be required if the collection used conformed to the Identifiable protocol.
Two parameters are passed to the second ScrollView component: the axis and showIndicators (ScrollView(.horizontal, showsIndicators: false). The .horizontal axis parameter causes content to be horizontal, and showIndictors:false prevents the scrollbar indicator from appearing in the view.
See also
Refer to the Apple ScrollView documentation at https://developer.apple.com/documentation/swiftui/scrollview.