Skip to content
This repository has been archived by the owner on Nov 21, 2017. It is now read-only.

Archived February 16, 2017 :: Core animation plan types for Apple devices

License

Notifications You must be signed in to change notification settings

material-motion-archive/coreanimation-swift

Repository files navigation

Core Animation for Material Motion (Swift)

Build Status codecov CocoaPods Compatible Platform Docs

This library provides a bridge between Core Animation and the Material Motion runtime.

Supported languages

  • Swift 3
  • Objective-C

Features

Tween uses Core Animation's CAKeyframeAnimation to animate a CALayer property along an easing curve.

Use a Tween like you would use a CAKeyframeAnimation instance: provide a key path, duration, and an array of values. Note that Tweens must be associated with CALayer instances.

let tweenBackgroundColor = Tween("backgroundColor",
                                 duration: animDuration,
                                 values: [UIColor.orange.cgColor, UIColor.lightGray.cgColor])
scheduler.addPlan(tweenBackgroundColor, to: myView.layer)

Tween's properties map to the following Core Animation properties:

Tween Core Animation
delay delay
duration duration
keyPath keyPath
keyPositions keyTimes
timingFunctions timingFunctions
values values

No other Core Animation properties are presently supported. View our filed feature requests to track progress on supporting additional functionality.

Installation

Installation with CocoaPods

CocoaPods is a dependency manager for Objective-C and Swift libraries. CocoaPods automates the process of using third-party libraries in your projects. See the Getting Started guide for more information. You can install it with the following command:

gem install cocoapods

Add MaterialMotionCoreAnimation to your Podfile:

pod 'MaterialMotionCoreAnimation'

Then run the following command:

pod install

Usage

Import the framework:

@import MaterialMotionCoreAnimation;

You will now have access to all of the APIs.

Example apps/unit tests

Check out a local copy of the repo to access the Catalog application by running the following commands:

git clone https://github.com/material-motion/coreanimation-swift.git
cd coreanimation-swift
pod install
open MaterialMotionCoreAnimation.xcworkspace

Guides

  1. How to animate a property with a Tween plan
  2. How to commit Tween values to a layer

How to animate a property with a Tween plan

Code snippets:

In Objective-C:

MDMTween *tween = [[MDMTween alloc] initWithKeyPath:@"<#key path#>"
                                           duration:<#duration#>
                                             values:@[<#values...#>]];
[scheduler addPlan:tween to:<#CALayer#>];

In Swift:

let tween = Tween(<#key path#>, duration: <#duration#>, values: [<#values...#>])
scheduler.addPlan(tween, to: <#CALayer#>)

How to animate a property with just a destination value

Provide Tween with a single value and it will treat this value as the toValue of a CABasicAnimation. As per the Core Animation documentation:

Interpolates between the layer's current value of the property in the render tree and `toValue'.

Code snippets:

In Objective-C:

MDMTween *tween = [[MDMTween alloc] initWithKeyPath:@"<#key path#>"
                                           duration:<#duration#>
                                             values:@[<#value#>]];
[scheduler addPlan:tween to:<#CALayer#>];

In Swift:

let tween = Tween(<#key path#>, duration: <#duration#>, values: [<#value#>])
scheduler.addPlan(tween, to: <#CALayer#>)

How to commit Tween values to a layer

We provide two helper APIs for committing the to/from value of a Tween plan to a given CALayer instance. This is most often used to commit the to value of the Tween to the layer so that the property does not appear to "snap back" upon completion of the animation.

Code snippets:

In Objective-C:

[tween commitFirstValueTo:<#CALayer#>];
[tween commitLastValueTo:<#CALayer#>];

In Swift:

tween.commitFirstValue(to: <#CALayer#>)
tween.commitLastValue(to: <#CALayer#>)

Contributing

We welcome contributions!

Check out our upcoming milestones.

Learn more about our team, our community, and our contributor essentials.

License

Licensed under the Apache 2.0 license. See LICENSE for details.

About

Archived February 16, 2017 :: Core animation plan types for Apple devices

Resources

License

Stars

Watchers

Forks

Packages

No packages published