我们定义了一个动画类来实现视图切换的动画效果,这个类只包含一个类方法,可直接调用,具体代码如下:
头文件:
| 1 2 3 4 5 6 7 8 9 10 11 12 13 | #import <Foundation/Foundation.h>@interfaceViewAnimation : NSObject/*============================页面切换的方法==============================    View1 表示当前页面    View2 表示目标页面    VC    两个view所在的viewController    共有12种动画效果和四个动画方向,这里采用随机挑选动画和方向的方案======================================================================*/+(void)TransView1:(UIView*)v1 View2:(UIView*)v2 VC:(UIViewController*)vc;@end | 
体文件:
| 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 | #import "ViewAnimation.h"#import <QuartzCore/QuartzCore.h>#define kDuration 0.4       //  动画效果持续时间(秒)@implementationViewAnimation//  页面切换的方法+(void)TransView1:(UIView*)v1 View2:(UIView*)v2 VC:(UIViewController *)vc;{    CATransition *animation = [CATransition animation];    animation.delegate = self;    animation.duration = kDuration;    animation.timingFunction = UIViewAnimationCurveEaseInOut;        switch(rand()%11) {        case1:            animation.type = kCATransitionFade;            break;        case2:            animation.type = kCATransitionPush;            break;        case3:            animation.type = kCATransitionReveal;            break;        case4:            animation.type = kCATransitionMoveIn;            break;        case5:            animation.type = @"cube";            break;        case6:            animation.type = @"suckEffect";            break;        case7:            animation.type = @"oglFlip";            break;        case8:            animation.type = @"rippleEffect";            break;        case9:            animation.type = @"pageCurl";            break;        case10:            animation.type = @"pageUnCurl";            break;        case11:            animation.type = @"cameraIrisHollowOpen";            break;        case0:            animation.type = @"cameraIrisHollowClose";            break;        default:            animation.type = kCATransitionMoveIn;            break;    }        switch(rand()%3) {        case0:            animation.subtype = kCATransitionFromLeft;            break;        case1:            animation.subtype = kCATransitionFromBottom;            break;        case2:            animation.subtype = kCATransitionFromRight;            break;        case3:            animation.subtype = kCATransitionFromTop;            break;        default:            animation.subtype = kCATransitionFromRight;            break;    }        [vc.view addSubview:v2];        NSIntegerx1 = [[vc.view subviews]indexOfObject:v1];    NSIntegerx2 = [[vc.view subviews]indexOfObject:v2];        [vc.view exchangeSubviewAtIndex:x1 withSubviewAtIndex:x2];    [[vc.view layer]addAnimation:animation forKey:@"animation"];}@end | 
为UIView视图切换添加动画效果,码迷,mamicode.com
原文地址:http://www.cnblogs.com/fizix100/p/3700062.html