CATransition动画来实现,
下面的代码是跳转到下一个视图:
CATransition *animation = [CATransition animation];
[animation setDuration:0.3];
[animation setType: kCATransitionPush];
[animation setSubtype: kCATransitionFromRight];//跳转方向样式
[animation setTimingFunction:[CAMediaTimingFunction functionWithName:kCAMediaTimingFunctionEaseInEaseOut]];
[self.navigationController pushViewController:searchResult animated:NO];//禁止导航动画
[self.navigationController.view.layer addAnimation:animation forKey:@"animation"];
只需把导航的动画禁掉,加上自己所需要的方向
下面的代码是返回前一个视图:
CATransition *animation = [CATransition animation];
[animation setDuration:0.3];
[animation setType: kCATransitionPush];
[animation setSubtype: kCATransitionFromLeft];
[animation setTimingFunction:[CAMediaTimingFunction functionWithName:kCAMediaTimingFunctionEaseInEaseOut]];
[self.navigationController.view.layer addAnimation:animation forKey:@"animation"];
[self.navigationController popViewControllerAnimated:NO];//禁止动画
返回前一个视图时有个注意点,禁止动画这一句必须写在动画代码的后面,否则达不到理想的效果。
/////////////////*********效果type**********//////////////////////
-
pageCurl 向上翻一页
-
pageUnCurl 向下翻一页
-
rippleEffect 滴水效果
-
suckEffect 收缩效果,如一块布被抽走
-
cube 立方体效果
-
oglFlip 上下翻转效果
-
cameraIrisHollowOpen 相机打开效果
-
cameraIrisHollowClose 相机关闭效果
-
Apple Developer Documents 中介绍
如下
11. NSString * const kCATransitionFade;
12. NSString * const kCATransitionMoveIn; 13. NSString * const
kCATransitionPush; 14. NSString * const
kCATransitionReveal;
过渡效果 type
fade //交叉淡化过渡(不支持过渡方向)
push //新视图把旧视图推出去
moveIn //新视图移到旧视图上面
reveal //将旧视图移开,显示下面的新视图
cube //立方体翻滚效果
oglFlip //上下左右翻转效果
suckEffect //收缩效果,如一块布被抽走(不支持过渡方向)
rippleEffect //滴水效果(不支持过渡方向)
pageCurl //向上翻页效果
pageUnCurl //向下翻页效果
cameraIrisHollowOpen //相机镜头打开效果(不支持过渡方向)
cameraIrisHollowClose //相机镜头关上效果(不支持过渡方向)
过渡方向 subtype
fromRight;
fromLeft;
fromTop;
fromBottom;