码迷,mamicode.com
首页 > 其他好文 > 详细

过场动画

时间:2014-07-15 23:09:22      阅读:267      评论:0      收藏:0      [点我收藏+]

标签:style   blog   http   color   使用   os   

简单的动画:
Core Animation是SDK四层结构中的第二层Media层中的重要组成部分,Quartz在这一层,而Core Animation位于Quartz之上,与Quartz的C语言函数库不同,它是基于Quartz的Objective-C封装。
所有的视图UIView 都有一个layer属性,即是CALayer对象,CALayer是Core Animation的基础。所有的Core Animation 动画都是基于CALayer的。CALayer的属性有(anchorPoint,backgroundColor,opacity,position,transform)
Core Animation 有两种动画类型:隐式动画 和显式动画
1.隐式动画(不需要显式的创建CABasicAnimation或CAAnimation对象)只需要在“动画块”中修改CALayer的属性:
(1)一个最简单示例
  [UIView beginAnimations:nil context:NULL];//1.标志“动画快"的开始
    CGAffineTransform moveTransform = CGAffineTransformMakeTranslation(200, 200);//2.创建一个放射变换对象。
    [self.baseView.layer setAffineTransform:moveTransform];//3.修改CALayer的transform属性
    self.baseView.layer.opacity = 1;//修改CALayer的opacity属性(动画效果是渐变)
    [UIView setAnimationDuration:1.0f];//4.设置动画持续时间,
    [UIView commitAnimations];//5.动画快结束标志,2)再给一个示例:这个例子是使用Block块,其中添加动画方法。
[UIView animateWithDuration:0.5 animations:^{
       [UIView setAnimationTransition:UIViewAnimationTransitionFlipFromLeft forView:self.window cache:NO];
        } completion:^(BOOL finished) {
      [_loadImgView removeFromSuperview];
  }];
(3)再来一个,这个实现程序退出,并结合了两个的功能中使用到的方法
#pragma mark - 退出程序动画操作
-(void)exitApplication{
    [UIView beginAnimations:@"exitApplication" context:nil];
    [UIView setAnimationDuration:0.5];
    [UIView setAnimationDelegate:self];
    UIWindow *win = [[UIApplication sharedApplication].windows objectAtIndex:0];
    [UIView setAnimationTransition:UIViewAnimationTransitionFlipFromRight forView:win cache:NO];
    [UIView setAnimationDidStopSelector:@selector(animationFinished:finished:context:)];
    win.bounds = CGRectMake(0, 0, 0, 0);
    [UIView commitAnimations];
}
-(void)animationFinished:(NSString *)animationID finished:(NSNumber *)finished context:(void *)context{
    if ([animationID compare:@"exitApplication"]==0) {
        exit(0);
    }
}
2.显式动画(需要显式地定义一个CABasicAnimation或CAAnimation对象来执行动画,其中有CABasicAnimation:CAPropertyAnimation,而CAPropertyAnimation:CAAnimation,CATransition:CAAnimation)
CATransition* transition = [CATransition animation];
    transition.duration = 0.5;
    transition.timingFunction = [CAMediaTimingFunction functionWithName:kCAMediaTimingFunctionEaseInEaseOut];
    transition.type = kCATransitionPush; //kCATransitionMoveIn; //, kCATransitionPush, kCATransitionReveal, kCATransitionFade//动画类型设置
    transition.subtype = kCATransitionFromTop; //kCATransitionFromLeft, kCATransitionFromRight, kCATransitionFromTop, kCATransitionFromBottom//动画开始点设置,动画开始方向设置。
    [self.navigationController.view.layer addAnimation:transition forKey:nil];
    [self.navigationController pushViewController:vc animated:NO];
以上动画都是过场性的,也就是说不是连续的持久的动画,能够满足页面跳转,界面显示等常见的功能,这部分的参考文档可以查看链接:http://www.open-open.com/lib/view/open1372152939072.html

 

过场动画,布布扣,bubuko.com

过场动画

标签:style   blog   http   color   使用   os   

原文地址:http://www.cnblogs.com/longtaozi/p/3843829.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!