The Wayback Machine - https://web.archive.org/web/20200601112709/https://github.com/roberthein/Ease
Skip to content
It's magic.
Swift
Branch: master
Clone or download

Latest commit

Latest commit 8862b30 Oct 11, 2019

Files

Permalink
Type Name Latest commit message Commit time
Failed to load latest commit information.
.build Small improvements to the interpolation function. Oct 7, 2019
.swiftpm/xcode/package.xcworkspace
Art Swift 5 updates. Mar 31, 2019
Ease Some cleanup. Oct 10, 2019
Example Fixed examples. Apr 15, 2019
Example3D Fixed examples. Apr 15, 2019
.gitattributes linguist-vendored Jun 6, 2019
.gitignore Initial commit. Dec 13, 2017
.travis.yml Initial commit. Dec 13, 2017
Ease.podspec Update versioning. Jun 7, 2019
LICENSE Initial commit. Dec 13, 2017
Package.swift iOS only Jun 6, 2019
README.md Update README.md Apr 9, 2019
_Pods.xcodeproj Initial commit. Dec 13, 2017

README.md

Ease

Ease is an event driven animation system that combines the observer pattern with custom spring animations as observers. It's magic.

Features

  • Animate any value type
  • Set multiple animations for a single value
  • Animation trajectories update when you update the targetValue
  • Add natural spring behavior to any value change
  • Optimized for Swift 5
  • Compatible with iOS 9 and up

Supported value types

  • CGFloat
  • CGPoint
  • CGSize
  • CGVector
  • Int
  • Float
  • Double
  • SCNVector3

Easily extendible with more (custom) types.

Examples

How

Create your Ease object with an initial value

var ease: Ease<CGPoint> = Ease(view.center, minimumStep: 0.001)

Add your custom spring-animation(s)

ease.addSpring(tension: 300, damping: 15, mass: 1) { position in
    view.center = position
}

Set the target value of your Ease object and adjust your target as often as you want

ease.targetValue = gestureRecognizer.location(in: view)

Memory management

For a single spring-animation you can store the returned EaseDisposable to a variable

disposable = ease.addSpring(tension...

For multiple spring-animations you can add the disposable to a EaseDisposal variable

ease.addSpring(tension...) { }.add(to: &disposal)

And always weakify self when referencing self inside your spring-animation

ease.addSpring(tension...) { [weak self] position in

Installation

Ease is available through CocoaPods. To install it, simply add the following line to your Podfile:

pod 'Ease'

Suggestions or feedback?

Feel free to create a pull request, open an issue or find me on Twitter.

You can’t perform that action at this time.