码迷,mamicode.com
首页 > 移动开发 > 详细

iOS开发日记16-动画Animation

时间:2015-09-09 17:06:13      阅读:210      评论:0      收藏:0      [点我收藏+]

标签:

今天博主有一个动画Animation的需求,遇到了一些困难点,在此和大家分享,希望能够共同进步.

iOS开发中的动画分为两种:一种为UIView动画,又称隐式动画,动画后frame的数值发生了变化.另一种是CALayer动画,又称显示动画,动画后模型层的数据不会发生变化,图形回到原来的位置.但是在实际开发中,因为UIView可以相应用户交互,所以UIView动画用的多.

一.UIview的动画

1.实现方式:动画块,block

begin

//设置动画效果  修改属性值,动画时长等等

conmmit

2.属性动画,过渡动画

①属性动画支持6种:transform 结构体 6个

②过渡动画:容器视图,两个子视图

二.CALayer动画  ==   核心动画   ==   CAAnimation动画

CAAnimation  抽象类

animation

①.CAAnimationGroup  组合动画

②.CATransition  过渡动画

③.CAPropertyAnimation  属性动画(layer的属性)

animationWithKeyPath

CABasicAnimation  基本动画

fromValue toValue

CAKeyFrameAnimation  关键帧动画

values

下面贴出UIView动画的代码,与大家分享,CALayer动画,也就是Core Animation各位看官可以自行百度.

1.

    //使用动画块设置动画

    

    //开始设置动画 第一个参数:动画的名字 第二个参数:可以用来传值

    [UIView beginAnimations:@"哈哈" context:nil];

    

    //设置动画的时长

    [UIView setAnimationDuration:1.5];

    [UIView setAnimationRepeatAutoreverses:YES];

    

    //根据需求设置视图的属性变化

    _showView.backgroundColor=[UIColor grayColor];

    _showView.center=CGPointMake(200, 200);

    

    //提交动画设置,开始执行动画

    [UIView commitAnimations];

 2.

    //使用Block设置动画

    

    [UIView animateWithDuration:1.5 animations:^{

        

        //动画效果设置

        _showView.backgroundColor=[UIColor yellowColor];

        //延时

        [UIView setAnimationDelay:1.0];

 

        //可以通过设置transform实现视图移动

          

    } completion:^(BOOL finished) {

        

        //动画完成后的设置

        NSLog(@"动画完成");

    }];

 

iOS开发日记16-动画Animation

标签:

原文地址:http://www.cnblogs.com/Twisted-Fate/p/4795227.html

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