RMPZoomTransitionAnimator alternatives and similar libraries
Based on the "Modal Transition" category.
Alternatively, view RMPZoomTransitionAnimator alternatives based on common mentions on social networks and blogs.
-
BubbleTransition
A custom modal transition that presents and dismiss a controller with an expanding bubble effect. -
ZOZolaZoomTransition
Zoom transition that animates the entire view heirarchy. Used extensively in the Zola iOS application. -
ImageOpenTransition
Beautiful and precise transitions between ViewControllers images written in Swift. -
DAExpandAnimation
A custom modal transition that presents a controller with an expanding effect while sliding out the presenter remnants. -
ElasticTransition-ObjC
A UIKit custom transition that simulates an elastic drag.This is the Objective-C Version of Elastic Transition written in Swift by lkzhao
InfluxDB - Purpose built for real-time analytics at any scale.
* Code Quality Rankings and insights are calculated and provided by Lumnify.
They vary from L1 to L5 with "L5" being the highest.
Do you think we are missing an alternative of RMPZoomTransitionAnimator or a related project?
README
RMPZoomTransitionAnimator
Overview
RMPZoomTransitionAnimator
provide a custom transition zooming animation.
Not only UICollectionView
, this is possible to use any other UIViewController
transition.
This transition animation is like the "Pinterest" animation, but this is very simple and small library.
[Screen shot](docs/collectionview.gif) [Screen shot](docs/tableview.gif)
Installation
RMPZoomTransitionAnimator is available through CocoaPods.
To install
it, simply add the following line to your Podfile:
pod "RMPZoomTransitionAnimator"
Usage
To run the example project, clone the repo, and run pod install
from the Example directory first.
Setup is as below:
Use for an UINavigationController push transition
Refer to the example project for details.
- Import
RMPZoomTransitionAnimator.h
- Adopt
RMPZoomTransitionAnimating
- Implement the
RMPZoomTransitionAnimating
protocol below, both source view controller and destination view controller- (UIImageView *)transitionSourceImageView
- (UIColor *)transitionSourceBackgroundColor
- (CGRect)transitionDestinationImageViewFrame
- Returns RMPZoomTransitionAnimator instance in the UINavigationController delegate method
- (id <UIViewControllerAnimatedTransitioning>)navigationController:(UINavigationController *)navigationController
animationControllerForOperation:(UINavigationControllerOperation)operation
fromViewController:(UIViewController *)fromVC
toViewController:(UIViewController *)toVC
{
// minimum implementation for example
RMPZoomTransitionAnimator *animator = [[RMPZoomTransitionAnimator alloc] init];
animator.goingForward = (operation == UINavigationControllerOperationPush);
animator.sourceTransition = (id<RMPZoomTransitionAnimating>)fromVC;
animator.destinationTransition = (id<RMPZoomTransitionAnimating>)toVC;
return animator;
}
Use for a modal transition
Refer to the example project for details.
- Import
RMPZoomTransitionAnimator.h
- Adopt
RMPZoomTransitionAnimating
- Implement
RMPZoomTransitionAnimating
protocol below, both source view controller and destination view controller- (UIImageView *)transitionSourceImageView
- (UIColor *)transitionSourceBackgroundColor
- (CGRect)transitionDestinationImageViewFrame
- Set the transitioningDelegate in
prepareForSegue:sender:
- Returns RMPZoomTransitionAnimator instance in the UIViewControllerTransitioningDelegate method
- (id<UIViewControllerAnimatedTransitioning>)animationControllerForPresentedController:(UIViewController *)presented
presentingController:(UIViewController *)presenting
sourceController:(UIViewController *)source
{
// minimum implementation for example
RMPZoomTransitionAnimator *animator = [[RMPZoomTransitionAnimator alloc] init];
animator.goingForward = YES;
animator.sourceTransition = (id<RMPZoomTransitionAnimating>)source;
animator.destinationTransition = (id<RMPZoomTransitionAnimating>)presented;
return animator;
}
- (id<UIViewControllerAnimatedTransitioning>)animationControllerForDismissedController:(UIViewController *)dismissed
{
// minimum implementation for example
RMPZoomTransitionAnimator *animator = [[RMPZoomTransitionAnimator alloc] init];
animator.goingForward = NO;
animator.sourceTransition = (id<RMPZoomTransitionAnimating>)dismissed;
animator.destinationTransition = (id<RMPZoomTransitionAnimating>)self;
return animator;
}
Requirements
- iOS 7.0 or higher
Change Log
1.0.3
- Add option to change default animation duration
- Fixed black screen
1.0.2
- Remove alpha view and source image view from superview when completed
1.0.1
- Adds animation completion handler
1.0.0
- First release.
Contribution
If you have feature requests or bug reports, feel free to help out by sending pull requests or by creating new issues.
Author
Masato Oshima Recruit Marketing Partners Co.,Ltd. [email protected]
License
RMPZoomTransitionAnimator is available under the MIT license.
*Note that all licence references and agreements mentioned in the RMPZoomTransitionAnimator README section above
are relevant to that project's source code only.