Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/hachinobu/SamuraiTransition
SamuraiTransition is an open source Swift based library providing a collection of ViewController transitions featuring a number of neat “cutting” animations.
https://github.com/hachinobu/SamuraiTransition
animation swift transition
Last synced: 2 months ago
JSON representation
SamuraiTransition is an open source Swift based library providing a collection of ViewController transitions featuring a number of neat “cutting” animations.
- Host: GitHub
- URL: https://github.com/hachinobu/SamuraiTransition
- Owner: hachinobu
- License: mit
- Created: 2016-11-26T05:06:47.000Z (about 8 years ago)
- Default Branch: master
- Last Pushed: 2019-06-12T12:46:21.000Z (over 5 years ago)
- Last Synced: 2024-11-28T20:50:11.268Z (3 months ago)
- Topics: animation, swift, transition
- Language: Swift
- Homepage:
- Size: 485 KB
- Stars: 279
- Watchers: 9
- Forks: 14
- Open Issues: 1
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
- awesome-ios - SamuraiTransition - Swift based library providing a collection of ViewController transitions featuring a number of neat “cutting” animations. (UI / Animation)
- awesome-swift - SamuraiTransition - Swift based library providing a collection of ViewController transitions featuring a number of neat cutting animations. (Libs / UI)
- awesome-swift - SamuraiTransition - Swift based library providing a collection of ViewController transitions featuring a number of neat cutting animations. (Libs / UI)
- awesome-ios-star - SamuraiTransition - Swift based library providing a collection of ViewController transitions featuring a number of neat “cutting” animations. (UI / Animation)
- fucking-awesome-swift - SamuraiTransition - Swift based library providing a collection of ViewController transitions featuring a number of neat cutting animations. (Libs / UI)
- awesome-swift - SamuraiTransition - SamuraiTransition is an open source Swift based library providing a collection of ViewController transitions featuring a number of neat “cutting” animations. ` 📝 2 years ago` (UI [🔝](#readme))
README
data:image/s3,"s3://crabby-images/7ff2d/7ff2db9639ce8f2320c65dd16780e81109a8cc20" alt="SamuraiTransition"
SamuraiTransiton is a ViewController transition framework in Swift.
It is an animation as if Samurai cut out the screen with a sword.
# transition types
|horizontal|vertical|diaonally|cross|
|:--:|:--:|:--:|:--:|
|data:image/s3,"s3://crabby-images/6f00a/6f00a00d55896496b9b96cee2ec245a34830c282" alt="horizontalzan"|data:image/s3,"s3://crabby-images/2d8e3/2d8e30392efb4627cff77e2ca3375dddfd10e318" alt="vertical"|data:image/s3,"s3://crabby-images/ede06/ede062868d9a687dddbc3c57d74d167f57f2c498" alt="diagonally"|data:image/s3,"s3://crabby-images/474cf/474cf09c28004619bff2c4d4a821f76f24e127f7" alt="cross"||x|jagged|circle|rectangle|
|:--:|:--:|:--:|:--:|
|data:image/s3,"s3://crabby-images/e9042/e90425ce514a05b3ac5005c4a73c7b742b4a4493" alt="x"|data:image/s3,"s3://crabby-images/56572/565721b73a8a33fc883ebf3526180da1c847a66d" alt="jagged"|data:image/s3,"s3://crabby-images/93455/93455f8ebe01de7943d47516adf443ea5ba9d0ed" alt="circle"|data:image/s3,"s3://crabby-images/4edc5/4edc546cfbb90b3cef0fc1924db37476b50aa0c9" alt="rectangle"||triangle|shredded|chopped|
|:--:|:--:|:--:|
|data:image/s3,"s3://crabby-images/0f6f7/0f6f7b9688e4bc81259315719a5c66440768c870" alt="triangle"|data:image/s3,"s3://crabby-images/f9abf/f9abfc547e7057bdb4c3ea9aa08abe4ea1846723" alt="shredded"|data:image/s3,"s3://crabby-images/4c674/4c674abb912e9475b5270e7e9c9b8a68ada170a9" alt="chopped"|# Usage
### Simple```swift
// make your view controller a subclass of SamuraiViewController
// present it as normalimport SamuraiTransition
class ModalViewController: SamuraiViewController {
//...
}class ViewController: UIViewController {
@IBAction func horizontalZan(_ sender: Any) {
let vc = UIStoryboard(name: "Main", bundle: nil).instantiateViewController(withIdentifier: "ModalViewController") as! ModalViewController
present(vc, animated: true, completion: nil)
}
@IBAction func verticalZan(_ sender: Any) {
let vc = UIStoryboard(name: "Main", bundle: nil).instantiateViewController(withIdentifier: "ModalViewController") as! ModalViewController
// customization
vc.samuraiTransition.zan = .vertical
present(vc, animated: true, completion: nil)
}
@IBAction func diagonallyZan(_ sender: Any) {
let vc = UIStoryboard(name: "Main", bundle: nil).instantiateViewController(withIdentifier: "ModalViewController") as! ModalViewController
// customization
vc.samuraiTransition.zan = .diagonally
present(vc, animated: true, completion: nil)
}}
```
### Attributes you can set
```swift
//Time of transition
public var duration: TimeInterval = 0.33
//presenting or not
public var presenting = true
//horizontal or vertical or diagonally
public var zan = Zan.horizontal
//enable or disable affine processing when ModalViewcontroller appears
public var isAffineTransform: Bool = true
//Passing point of the sword line
public var zanPoint: CGPoint?
//sword line color
public var zanLineColor = UIColor.black
//sword line width
public var zanLineWidth: CGFloat = 1.0```
### Custom
```swift
class ViewController: UIViewController {
let transition = SamuraiTransition()
override func viewDidLoad() {
super.viewDidLoad()
transition.duration = 1.0
transition.zan = Zan.vertical
transition.isAffineTransform = false
transition.zanLineColor = .blue
transition.zanLineWidth = 2.0
}@IBAction func tapModalButton(_ sender: AnyObject) {
let vc = UIStoryboard(name: "Main", bundle: nil).instantiateViewController(withIdentifier: "ModalViewController") as! ModalViewController
let button = sender as! UIButton
transition.zanPoint = CGPoint(x: button.center.x, y: button.center.y)
// vc.transitioningDelegate = transition
vc.transitioningDelegate = self
present(vc, animated: true, completion: nil)
}}
extension ViewController: UIViewControllerTransitioningDelegate {
func animationController(forPresented presented: UIViewController, presenting: UIViewController, source: UIViewController) -> UIViewControllerAnimatedTransitioning? {
transition.presenting = true
return transition
}
func animationController(forDismissed dismissed: UIViewController) -> UIViewControllerAnimatedTransitioning? {
transition.presenting = false
return transition
}
}```
# Requirements
* Xcode 10 or higher
* iOS 9.0 or higher
* Swift 5.0# Installation
#### [CocoaPods](https://github.com/cocoapods/cocoapods)`pod 'SamuraiTransition'`
#### [Carthage](https://github.com/Carthage/Carthage)
- Insert `github "hachinobu/SamuraiTransition"`
- Run `carthage update`.
- Link your app with `SamuraiTransition.framework` in `Carthage/Build`.# License
SamuraiTransiton is available under the MIT license. See the LICENSE file for more info.