Ecosyste.ms: Awesome

An open API service indexing awesome lists of open source software.

Awesome Lists | Featured Topics | Projects

https://github.com/nathangitter/fluid-interfaces

Natural gestures and animations inspired by Apple's WWDC18 talk "Designing Fluid Interfaces"
https://github.com/nathangitter/fluid-interfaces

animation fluid gesture interfaces spring-animation swift

Last synced: 7 days ago
JSON representation

Natural gestures and animations inspired by Apple's WWDC18 talk "Designing Fluid Interfaces"

Awesome Lists containing this project

README

        

Fluid Interfaces Title Graphic

### Check out the accompanying blog post for more details: [Building Fluid Interfaces](https://medium.com/@nathangitter/building-fluid-interfaces-ios-swift-9732bb934bf5)

⭐️ If you found this repo helpful, please star it. Thanks! ⭐️

### Background

At WWDC 2018, Apple designers gave a talk titled "Designing Fluid Interfaces", explaining the design theory behind the gesture-based interface of iPhone X. (The presentation is available here: [Designing Fluid Interfaces](https://developer.apple.com/videos/play/wwdc2018/803/))

It was an outstanding talk, inspiring designers and developers to think about animated interfaces in a new way. While some technical guidance was provided, most code-level implementation details were ommitted.

The goal with this project is to bridge the gap between inspiration and implementation.

### Installation

Download or clone the repo and open the `FluidInterfaces.xcodeproj` file with Xcode.

### Interfaces

[Calculator Button](#calculator-button)

[Spring Animations](#spring-animations)

[Flashlight Button](#flashlight-button)

[Rubberbanding](#rubberbanding)

[Acceleration Pausing](#acceleration-pausing)

[Rewarding Momentum](#rewarding-momentum)

[FaceTime PiP](#facetime-pip)

[Rotation](#rotation)

## Calculator Button

A button that mimics the behavior of buttons in the iOS Calculator app.

Calculator Button Demo

[⚙️ CalculatorButton.swift](FluidInterfaces/FluidInterfaces/CalculatorButton.swift)

[📺 Designing Fluid Interfaces 50:13](https://developer.apple.com/videos/play/wwdc2018/803/?time=3013)

## Spring Animations

A demo showing the ability to define a spring animation with "design-friendly" parameters.

Spring Demo

[⚙️ Spring.swift](FluidInterfaces/FluidInterfaces/Spring.swift)

[📺 Designing Fluid Interfaces 31:40](https://developer.apple.com/videos/play/wwdc2018/803/?time=1900)

## Flashlight Button

A button that mimics the behavior of the flashlight button on the lockscreen of iPhone X.

Flashlight Button Demo

[⚙️ FlashlightButton.swift](FluidInterfaces/FluidInterfaces/FlashlightButton.swift)

[📺 Designing Fluid Interfaces 37:59](https://developer.apple.com/videos/play/wwdc2018/803/?time=2279)

## Rubberbanding

A demo showing how to implement rubberbanding.

Rubberbanding Demo

[⚙️ Rubberbanding.swift](FluidInterfaces/FluidInterfaces/Rubberbanding.swift)

[📺 Designing Fluid Interfaces 17:01](https://developer.apple.com/videos/play/wwdc2018/803/?time=1021)

## Acceleration Pausing

A demo of using a gesture's acceleration to quickly detect when the user's motion has paused.

Acceleration Pausing Demo

[⚙️ Acceleration.swift](FluidInterfaces/FluidInterfaces/Acceleration.swift)

[📺 Designing Fluid Interfaces 10:40](https://developer.apple.com/videos/play/wwdc2018/803/?time=640)

## Rewarding Momentum

A drawer with an open and closed state which has bounciness dependent on the velocity of the gesture.

Rewarding Momentum Demo

[⚙️ Momentum.swift](FluidInterfaces/FluidInterfaces/Momentum.swift)

[📺 Designing Fluid Interfaces 36:48](https://developer.apple.com/videos/play/wwdc2018/803/?time=2208)

## FaceTime PiP

A re-creation of the picture-in-picture UI of the iOS FaceTime app.

FaceTime PiP Demo

[⚙️ Pip.swift](FluidInterfaces/FluidInterfaces/Pip.swift)

[📺 Designing Fluid Interfaces 41:56](https://developer.apple.com/videos/play/wwdc2018/803/?time=2516)

## Rotation

A demo showing how the concepts from the PiP interface can apply to other animations.

Rotation Demo

[⚙️ Rotation.swift](FluidInterfaces/FluidInterfaces/Rotation.swift)

[📺 Designing Fluid Interfaces 47:25](https://developer.apple.com/videos/play/wwdc2018/803/?time=2845)

## Author
You can find me on Twitter [@nathangitter](https://twitter.com/nathangitter)

## Contributing
Feel free to add issues or pull requests here on GitHub. I cannot guarantee that I will accept your changes, but feel free to fork the repo and make changes as you see fit. Thanks!

## License & Copyright
© 2018 Nathan Gitter, licensed under Apache-2.0. See LICENSE for more information.