Email or username:

Password:

Forgot your password?
Top-level
Lickability

Gradients can be interpolated in two ways: by color space (how colors are mixed) or by easing function (how colors change over distance). The default linear easing in tools like Figma and CSS creates a harsh line. The Podcasts app appears to use a custom, easing function:

Two gradients, both go from black at the top to transparent at 50% from the bottom. The first gradient is linear eased and it’s easy to spot where the gradient begins. The second gradient uses an ease-in-out curve and the effect is smoothed out.
4 comments
Lickability

By the way, @dlx figured out how SwiftUI handles the other type of interpolation — it uses the Oklab color space rather than sRGB, which is what Figma uses. So if your designs look different between the two, that could be why.

mastodon.social/@dlx/109784856

Lickability

Like the Sports app, the transcript makes heavy use of vibrancy text effects on top of a procedurally-generated motion background so the de-emphasized text still takes on some color from the background. More on that here:

mastodon.social/@lickability/1

Lickability

The player background is the same as Apple Music — it warps and twists the episode artwork and blurs it to make this mesh gradient effect. Our designer,
@samhenrigold, did a deep dive into that if you’re curious how it works:

hachyderm.io/@samhenrigold/112

Lickability

Finally, swipe down the player slowly and notice the corners of that player sheet. It matches the corner radius of the display! Unfortunately, this isn’t a documented API. It’s stored as a key on UIScreen called `_displayCornerRadius` which you totally shouldn’t obfuscate & use.

The episode player sheet mid-drag wrapped in an iPhone 15 Pro frame. The shape of the player sheet has a purple outline and the iPhone display has an orange outline — they’re the same radius (55 points).
Go Up