herotransitions/hero
**Hero** is a library for building iOS view controller transitions. It provides a declarative layer on top of the UIKit's cumbersome transition APIs—making custom transitions an easy task for developers.
Usage Example 1
<img src="https://cdn.rawgit.com/lkzhao/Hero/ebb3f2c/Resources/simple.svg" />
View Controller 1
redView.hero.id = "ironMan"
blackView.hero.id = "batMan"View Controller 2
self.hero.isEnabled = true
redView.hero.id = "ironMan"
blackView.hero.id = "batMan"
whiteView.hero.modifiers = [.translate(y:100)]Usage Example 2
<img src="https://cdn.rawgit.com/lkzhao/Hero/ebb3f2c/Resources/advanced.svg" />
View Controller 1
greyView.hero.id = "skyWalker"View Controller 2
self.hero.isEnabled = true
greyView.hero.id = "skyWalker"
// collectionView is the parent view of all red cells
collectionView.hero.modifiers = [.cascade]
for cell in redCells {
cell.hero.modifiers = [.fade, .scale(0.5)]
}You can do these in the storyboard too!
<img src="https://cdn.rawgit.com/lkzhao/Hero/master/Resources/storyboardView.png" width="267px"/> <img src="https://cdn.rawgit.com/lkzhao/Hero/master/Resources/storyboardViewController.png" width="267px"/>
Installation
CocoaPods
Add the following entry to your Podfile:
pod 'Hero'Then run pod install.
Don't forget to import Hero in every file you'd like to use Hero.
Carthage
Add the following entry to your Cartfile:
github "HeroTransitions/Hero"Then run carthage update.
If this is your first time using Carthage in the project, you'll need to go through some additional steps as explained over at Carthage.
Accio
Add the following to your Package.swift:
.package(url: "https://github.com/HeroTransitions/Hero.git", .upToNextMajor(from: "1.4.0")),Next, add Hero to your App targets dependencies like so:
.target(
name: "App",
dependencies: [
"Hero",
]
),Then run accio update.
Swift Package Manager
To integrate using Apple's Swift package manager, add the following as a dependency to your Package.swift:
.package(url: "https://github.com/HeroTransitions/Hero.git", .upToNextMajor(from: "1.3.0"))and then specify "Hero" as a dependency of the Target in which you wish to use Hero. Here's an example PackageDescription:
// swift-tools-version:4.0
import PackageDescription
let package = Package(
name: "MyPackage",
products: [
.library(
name: "MyPackage",
targets: ["MyPackage"]),
],
dependencies: [
.package(url: "https://github.com/HeroTransitions/Hero.git", .upToNextMajor(from: "1.6.3"))
],
targets: [
.target(
name: "MyPackage",
dependencies: ["Hero"])
]
)Manually
- Drag the Sources folder anywhere in your project.
Documentations
Checkout the WIKI PAGES (Usage Guide) for documentations.
For more up-to-date ones, please see the header-doc. (use alt+click in Xcode) <img src="https://cdn.rawgit.com/lkzhao/Hero/master/Resources/headerDoc.png" width="521px"/>
Dash compatible API docs: https://HeroTransitions.github.io/Hero/
Interactive Transition Tutorials
FAQ
Not able to use Hero transition even when self.hero.isEnabled is set to true
Make sure that you have also enabled self.hero.isEnabled on the navigation controller if you are doing a push/pop inside the navigation controller.
Views being covered by another matched view during the transition
Matched views use global coordinate space while unmatched views use local coordinate space by default. Local coordinate spaced views might be covered by other global coordinate spaced views. To solve this, use the useGlobalCoordinateSpace modifier on the views being covered. Checkout Coordinate Space Wiki page for details.
Push animation is shown along side my custom animation
This is the default animation for navigation controller provided by Hero. To disable the push animation, set self.hero.navigationAnimationType to .fade or .none on the navigation controller.
How do I use a different default animation when dismissing
You can use the animation type .selectBy(presenting:dismissing) to specify a different default animation for dismiss.
For example:
self.hero.modalAnimationType = .selectBy(presenting:.zoom, dismissing:.zoomOut)Contribute
We welcome any contributions. Please read the Contribution Guide.
Package Metadata
Repository: herotransitions/hero
Default branch: master
README: README.md