Cheetah

Easy animation library on iOS with Swift2

  • Owner: suguru/Cheetah
  • Platform:
  • License:: MIT License
  • Category::
  • Topic:
  • Like:
    0
      Compare:

Github stars Tracking Chart

Cheetah

Carthage compatible
Pod Version
Swift Version
License MIT
Plaforms

Cheetah is an animation utility on iOS with Swift. Cheetah can animate any properties
since Cheetah uses simple CADisplayLink run loop to change animated properties.

Requirements

  • iOS 8.0~
  • tvOS 9.0~
  • Swift 3.0

Features

  • Animation with duration and delay
  • Changing with absolute/relative properties
  • Parallel/Serial executions
  • Easings
  • Springs

Carthage

Carthage is a simple, decentralized dependency manager for Cocoa.

To install Cheetah, simply add the following line to your Cartfile:

github "suguru/Cheetah"

Code Example

// Create view
let box = UIView(frame:CGRectMake(100,100,50,50))
box.backgroundColor = UIColor.blueColor()
view.addSubview(box)

// Move to 100px right
box.cheetah.move(100, 0).run()

Simple move

Properties

Cheetah has several methods to animate properties easily. You can also animate your own properties with extending CheetahProperty.

  • move
  • position (absolute of move)
  • scale
  • rotate
  • rotation (absolute of rotate)
  • size
  • frame
  • alpha
  • backgroundColor
  • textColor
  • borderColor
  • borderWidth
  • borderRadius
  • custom properties

Parallel execution

Cheetah groups animation properties and execute them at once.

view.cheetah
  .move(100, 0)
  .rotate(M_PI * 2)
  .scale(1.5)
  .run()

Parallel

Serial execution

wait will wait until all animations placed before it completed.
It can also receive seconds to wait to start next animation.

view.cheetah
  .move(100, 0).rotate(M_PI)
  .wait()
  .move(-100, 0).rotate(-M_PI)
  .wait(1.0) // <- wait 1 sec to start next animation
  .move(0, -20).duration(0.4)
  .wait()
  .move(0, 20).duration(0.4)
  .run()

Serial

Duration and delay

Cheetah has duration and delay to each animation properties.

view.cheetah
  .move(100, 0).duration(1.0).delay(1.0)
  .rotate(M_PI).duration(2.0)
  .wait(1)
  .move(-100, 0).duration(0.4)
  .run()

Delay

Duration will be copied from the property placed before.

view.cheetah
  .duration(0.5)
  .move(100, 0) // <- will have 0.5 sec duration
  .rotate(M_PI) // <- will have 0.5 sec duration
  .run()

Repeating

To repeat animations, use repeatCount(count: Int)

view.cheetah.rotate(M_PI_2).run().repeat(3)

To repeat forever, use forever

view.cheetah.rotate(M_PI_2).run().forever

Repeat

Easings

Cheetah supports various easing functions. You can also add custom easings with quad bezier points.

Easings

Exmaple

view.cheetah.move(150, 150).easeInQuad.run()

Supported eassing equations

  • Linear
  • Sine
  • Quad
  • Quart
  • Quint
  • Circ
  • Cubic
  • Expo
  • Back
  • Bounce
  • Elastic

Springs

Cheetah supports spring dynamics with tension and friction parameters.

Springs

Example

view.cheetah
  .move(200, 0)
  .spring()
  .run()

view.cheetah
  .move(200, 0)
  .spring(tension: 100, friction: 4)
  .run()

Animate custom properties

You can extend CheetahProperty to animate custom properties. You can refer CheetahViewProperties.swift and CheetahLayerProperties.swift.

:)

Main metrics

Overview
Name With Ownersuguru/Cheetah
Primary LanguageSwift
Program languageSwift (Language Count: 3)
Platform
License:MIT License
所有者活动
Created At2015-08-21 00:31:23
Pushed At2018-10-03 13:28:32
Last Commit At2016-10-20 00:13:37
Release Count13
Last Release Name0.4.1 (Posted on 2016-10-20 00:08:31)
First Release Name0.1.0 (Posted on 2015-08-22 01:39:55)
用户参与
Stargazers Count589
Watchers Count18
Fork Count47
Commits Count43
Has Issues Enabled
Issues Count11
Issue Open Count7
Pull Requests Count2
Pull Requests Open Count1
Pull Requests Close Count1
项目设置
Has Wiki Enabled
Is Archived
Is Fork
Is Locked
Is Mirror
Is Private