Skip to content

mspviraj/Hero

 
 

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

32 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

Supercharged transition engine for iOS. Build your custom view transitions with few lines of code or even no code at all. Inspired by Polymer's neon-animated-pages and Keynote's Magic Move.

Version License Xcode 8.0+ iOS 8.0+ Swift 3.0+

Video Demo

View here

Usage Guide

Read here

What is Hero?

Hero is a library for building iOS view controller transitions. It provides extensions and an API layer on top of the UIKit's cumbersome transition APIs. Making custom transitions a easy task for developers.

At its core, Hero provides a automatic transition similar to Keynote's Magic Move. It does this by checking the heroID property on both view controllers' subviews. Every matched view pairs are then automatically transitioned from it's old state to it's new state.

Hero is also able to construct animations for other views that are not matched. It is super easy to define those animations via the heroModifiers property. and Hero will run these animations alongside the Magic Move animations. Not only that, Hero is able to handle everything interactively, too.

Hero does all of these without any assumption about how the view is built or structured. It will not modify any of your views' states other than hidding them during the animation. This means that it works great with autolayout, programmatic layout, UICollectionView, UITableView, UINavigationController etc...

Tl;dr: This is what Hero does:

  • Automatically transition matched views between view controllers
  • Built in animations for unmatched views:
    • Fade
    • Scale
    • Rotate
    • Translate
    • Position
    • Bounds
  • Attributes to tweak animation properties for each views independently
    • Easing (Timing Functions)
    • Spring Damping
    • Spring Stiffness
  • Works with
    • Autolayout
    • Programmatic Layout
    • UINavigationController
    • UITableView
    • UICollectionView (without messing with UICollectionViewLayout)
  • Apply cascade effects to these animations
  • Super slim API for making all of these interactive!

Quick Guide

Basic HeroID Tutorial

To achieve the transition above (3 steps)

  1. Setup the view controllers and construct the view hierarchy

  1. Using either the StoryBoard's Identity Inspector or by code, set views' heroID

or

blueView.heroID = "blue"

Remember to set heroID to both the source view and the destination view

  1. Enable Hero Transition to the destination view controller (ViewController2)

or

viewController2.isHeroEnabled = true

More to come

For detailed explaination about how Hero ID, Hero Modifiers, and supported animations, read the Usage Guide, or download the Source Code.

License

Hero is available under the MIT license. See the LICENSE file for more info.

About

Supercharged transition engine for iOS.

Resources

License

Stars

Watchers

Forks

Packages

No packages published

Languages

  • Swift 99.0%
  • Ruby 1.0%