WXSTransition 这款非常不错,力推
这是作者源码简书地址:
http://www.jianshu.com/p/fd3154946919
这是作者源码github地址
https://github.com/alanwangmodify/WXSTransition
大家可以去下载来看看,喜欢的话给作者个Star。
bug修改:
1、A页面用push动画到B页面,B页面PUSH到C页面,也会有这样的动画效果;
修改:可以在B到C的时候将导航栏的delegate设为nil,就能正常跳转了,应该是导航栏代理没有置空的问题
介绍
transition animation asset一个界面转场动画集。
在平时开发中,有时候需要一些转场动画给界面调整增添一些活力,而实现这些动画相对比较繁琐。为了让实现转场更简单,我写了这个界面转场动画集。调整界面时,只要一行代码就可以实现这里面的动画。包括系统提供的动画在内,目前有大概50种动画。
使用方法
1、首先导入头文件
#import "UINavigationController+WXSTransition.h"
2、一行代码就可以调用
Push:
[self.navigationController wxs_pushViewController:(UIViewController *) animationType:(WXSTransitionAnimationType)];
Present:
[self wxs_presentViewController:(UIViewController *) animationType:(WXSTransitionAnimationType) completion:^{}];
说明:WXSTransitionAnimationType
是转场动画类型,通过这个枚举选择你想要的转场动画。
3、支持属性修改
[self wxs_presentViewController:<#(UIViewController *)#> makeTransition:^(WXSTransitionManager *transition) {
transition.animationType = WXSTransitionAnimationTypePointSpreadPresent;
transition.animationTime = 1;
}];
可以通过transition
设置动画时间、类型等属性,目前可修改属性不多,以后版本会增加
4、特殊调用
像point Spread
、ViewMoveToNextVC
这样的动画,需要个起始view,只要将目标控制器的startView指向这个view就可以了,代码如下;
data:image/s3,"s3://crabby-images/e89e8/e89e8f12c6e06e0dcc7853ab5576eb12fdd5317d" alt=""
DetailViewController *vc = [[DetailViewController alloc] init];
CollectionViewCell *cell = (CollectionViewCell *)[collectionView cellForItemAtIndexPath:indexPath];
vc.startView = cell.imgView;
[self.navigationController wxs_pushViewController:vc makeTransition:^(WXSTransitionManager *transition) {
transition.animationType = WXSTransitionAnimationTypeViewMoveToNextVC;
transition.animationTime = 1;
}];
动画效果图
自定义动画
data:image/s3,"s3://crabby-images/3faad/3faadbb68afae4704673ea7502ad3dd3bac189ec" alt=""
boom.gif
data:image/s3,"s3://crabby-images/78bd6/78bd6869e78669a2aad800322da48196cfe03d9d" alt=""
brick_close_H.gif
data:image/s3,"s3://crabby-images/30678/30678bb3b35dc13e1cf6c0ca7cdc9be87bed53be" alt=""
brick_open_V.gif
data:image/s3,"s3://crabby-images/a4df3/a4df3d397ae38596502e69e92eeb732774326f85" alt=""
cover.gif
data:image/s3,"s3://crabby-images/d2eed/d2eedf8eb3c676f91b312d8abbf1a61f8dd05e54" alt=""
point_spread.gif
data:image/s3,"s3://crabby-images/7e76c/7e76c6fe24e7949570352c35dffc19c246f179ae" alt=""
spread_from_right.gif
data:image/s3,"s3://crabby-images/2c97e/2c97ec47d60020d0bb2b4bb1f673b2e4f80cedec" alt=""
spread_from_top.gif
data:image/s3,"s3://crabby-images/e89e8/e89e8f12c6e06e0dcc7853ab5576eb12fdd5317d" alt=""
view_move_next.gif
系统动画
iOS自身其实有许多不错的转场动画,在这个转场动画集里也进行了封装,使用方法跟自定义转场动画一样。
Push:
[self.navigationController wxs_pushViewController:<#(UIViewController *)#> animationType:<#(WXSTransitionAnimationType)#>];
Present:
[self wxs_presentViewController:<#(UIViewController *)#> animationType:<#(WXSTransitionAnimationType)#> completion:<#^(void)completion#>]
data:image/s3,"s3://crabby-images/e1c76/e1c761ae30c9638785f2a1ad84655a35ea80fa4a" alt=""
sys_oglFlip.gif
data:image/s3,"s3://crabby-images/69259/69259341a2227a7dd49238ecc010ac1c2fd8cfdb" alt=""
sys_pageCurl.gif
后语
现在是第一个版本,原本准备支持交互手势,但是一些动画使用了交互手势存在许多问题,所以这个版本去除了,准备在以后的版本中增加一些一下功能:1、添加一些酷炫的转场动画2、支持交互手势3、提供自定义动画接口,让使用者想实现自己的转场动画时,不用实现各种代理等繁琐工作,专注于fromVC,和toVC的动画逻辑。
最后再提供一下gittub 链接。WXSTransition
文/Alan1_iOS(简书作者)原文链接:http://www.jianshu.com/p/fd3154946919著作权归作者所有,转载请联系作者获得授权,并标注“简书作者”。
网友评论