I spent a lot of time looking for a way to recreate the UI of the ScrollViews in Stock Apple Apps (i.e. App Store and Apple Music) inside of SwiftUI.
And here is the result! I call it FancyScrollView.
It’s a ScrollView with a few extra perks:
Fancy Blur when scrolling
Use a FancyScrollView instead of a normal ScrollView and it will add a nice blur in the safe area. Making your View look much cleaner while scrolling!
FancyScrollView {
VStack {
...
}
}
Result:
Including a Header
I was really surprised by the fact I couldn’t find a proper Package for adding a nice Parallax header to a ScrollView. So I included it here! And you can customize everything about it:
Scrolling Up Behavior:
You can specify one of two behaviors:
public enum ScrollUpHeaderBehavior {
case parallax // Will zoom out all pretty ;)
case sticky // Will stay at the top
}
Scrolling Down Behavior:
public enum ScrollDownHeaderBehavior {
case offset // Will move the header with the content
case sticky // Will stay at the top and the content will cover the header
}
Let’s see them in action!
Here’s every combination between scrolling behaviors
Parallax + Offset (Default):
This is the default and appears to be the most neutral and standard version of the ScrollView Header in the Market. Chances are, you want this one!
FancyScrollView
I spent a lot of time looking for a way to recreate the UI of the ScrollViews in Stock Apple Apps (i.e. App Store and Apple Music) inside of SwiftUI.
And here is the result! I call it
FancyScrollView
. It’s a ScrollView with a few extra perks:Fancy Blur when scrolling
Use a
FancyScrollView
instead of a normalScrollView
and it will add a nice blur in the safe area. Making your View look much cleaner while scrolling!Result:
Including a Header
I was really surprised by the fact I couldn’t find a proper Package for adding a nice Parallax header to a ScrollView. So I included it here! And you can customize everything about it:
Scrolling Up Behavior:
You can specify one of two behaviors:
Scrolling Down Behavior:
Let’s see them in action!
Here’s every combination between scrolling behaviors
Parallax + Offset (Default):
This is the default and appears to be the most neutral and standard version of the ScrollView Header in the Market. Chances are, you want this one!
Result:
Parallax + Sticky:
This combination is designed to imitate the header from the Artist Detail View in Apple Music.
Result:
Sticky + Offset:
This combination is designed to imitate the header from the “Today” showcases in the App Store.
Result:
Sticky + Sticky:
I’m not sure who’s looking for this behavior, but it looks cool. So, you do you!
Result:
Known Issues
NavigationView