分享

IOS视图切换实现简单动画

 叹落花 2014-12-20
1.两个简单视图间的切换算法。
  1. if (self.pRedViewController.view.superview == nil)  
  2.     {  
  3.         if (self.pRedViewController.view == nil)  
  4.         {  
  5.             LinRedViewController * red = [[LinRedViewController alloc]initWithNibName:nil bundle:nil];  
  6.             self.pRedViewController = red;  
  7.             [red release];  
  8.         }  
  9.         [self.pYellowViewController.view removeFromSuperview];  
  10.         [self.view insertSubview:self.pRedViewController.view atIndex:0];  
  11.     }  
  12.     else  
  13.     {  
  14.         if (self.pYellowViewController.view.superview == nil)  
  15.         {  
  16.             if (self.pYellowViewController.view == nil)  
  17.             {  
  18.                 LinYellowViewController * yellow = [[LinYellowViewController alloc]initWithNibName:nil bundle:nil];  
  19.                 self.pYellowViewController =yellow;  
  20.                 [yellow release];  
  21.             }  
  22.             [self.pRedViewController.view removeFromSuperview];  
  23.             [self.view insertSubview:self.pYellowViewController.view atIndex:0];  
  24.         }  
  25.     }  
判断当前pRedViewController视图的超视图是否空,若为空则判断当前pRedViewController是否为空,若为空则设置临时变量red,再赋给pYellowViewController,释放临时变量,接着把当前的pRedViewController去除,加入pYellowViewController视图;反之则亦然。把此导人到下面两个方法中,即可实现简单动画。
2.在UIView类下,通过Animation框架实现动画效果。
  1.  //设置动画的名字  
  2. [UIView beginAnimations:@"Animation" context:nil];  
  3.  //设置动画的间隔时间  
  4.  [UIView setAnimationDuration:1.5];  
  5.  //设置动画的速率  
  6.  [UIView setAnimationCurve:UIViewAnimationCurveEaseIn];  
  7.  //设置动画的方式  
  8.  [UIView setAnimationTransition:UIViewAnimationTransitionFlipFromLeft forView:self.view cache:YES];  
  9.   
  10.   
  11. //UIView动画的结束方式  
  12. [UIView commitAnimations];  
3.导入QuartzCore/QuartzCore.h框架,利用图层思想实现动画。
  1. //导入QuartzCore/QuartzCore.h框架,实现动画  
  2.     CATransition *transiton = [CATransition animation];  
  3.     transiton.delegate = self;  
  4.     transiton.duration = 1.25;  
  5.     transiton.timingFunction = UIViewAnimationCurveEaseInOut;  
  6.     transiton.subtype = kCATransitionFromRight;  
  7.     transiton.type = @"pageUnCurl";  
  8.     //(各种动画效果)@"cube"(方块式动画) @"moveIN(插入替换动画)" @"reveal"(幕帘式动画-推) @"fade"(default)(逐渐替换式,是系统默认的动画方式-当不写caswitch.type时,系统的动画方式就是fade) @"pagecurl"(类似逐渐替换动画) @"pageUnCurl"(不规则翻页式动画) @"suckEffect" @"rippleEffect" @"oglFlip"  
  9.   
  10.   
  11. //QuartzCore/QuartzCore.h框架时动画的结束,layer寻找图层  
  12.     [self.view.layer addAnimation:transiton forKey:nil];  

    本站是提供个人知识管理的网络存储空间,所有内容均由用户发布,不代表本站观点。请注意甄别内容中的联系方式、诱导购买等信息,谨防诈骗。如发现有害或侵权内容,请点击一键举报。
    转藏 分享 献花(0

    0条评论

    发表

    请遵守用户 评论公约

    类似文章 更多