[iOS]iOS的UI animation 简单整理

iOS 做动画,主要是2种方式,初学者或者常见动画UIKit就可以搞定,如果是较为复杂的动画,则需要coreAnimation.

1.UIKit

代码来自CSDN的博客
感谢这位有心的博主

1.1 通过动画上下文使用UIKit动画

 [self.view addSubview:redView];  
    //开始动画  
    [UIView beginAnimations:@"test" context:nil];  
    //动画时长  
    [UIView setAnimationDuration:1];  
    /*  
     *要进行动画设置的地方  
     */  
      
    redView.backgroundColor=[UIColor blueColor];  
    redView.frame=CGRectMake(50, 50, 200, 200);  
    redView.alpha=0.5;  
      
    //动画结束  
    [UIView commitAnimations];

1.2 通过代码块使用UIKit动画

[UIView animateWithDuration:1 //时长  
                          delay:0 //延迟时间  
                        options:UIViewAnimationOptionTransitionFlipFromLeft//动画效果  
                     animations:^{  
                           
                         //动画设置区域  
                         redView.backgroundColor=[UIColor blueColor];  
                         redView.frame=CGRectMake(50, 50, 200, 200);  
                         redView.alpha=0.5;  
                           
                     } completion:^(BOOL finish){  
                       //动画结束时调用  
                       //............  
                     }];  

2. 使用Core Animation对象来实现动画

CABasicAnimation
CAKeyframeAnimation
CATransitionAnimation

其中CABasicAnimation和CAKeyframeAnimation是对图层中的不同属性进行动画的。
如果要多整个图层进行动画,则应该使用CATransitionAnimation
如果要使用组合动画,例如要改变图层的大小和透明度,则可以先为每个属性创建一个CABasicAnimation对象,再把他们组合到CAAnimationGroup中,最后把这个组合添加到要进行动画的CALayer中。
注:CAAnimation(以及CAAnimation的子类),全部都是显式动画,这样动画播放后,表现层回恢复到模型层的原始状态,这就意味着,如果动画播放完后,会恢复到原来的样子,所以在动画播放完后要对模型层进行修改,例如:self.view.layer.backgroundColor=[UIColor blueColor].CGColor;

2.1 CABasicAnimation

-(void)animationOfCABasicAnimation  
{  
    //创建一个CABasicAnimation对象  
    CABasicAnimation *animation=[CABasicAnimation animation];  
    //设置颜色  
    animation.toValue=(id)[UIColor blueColor].CGColor;  
    //动画时间  
    animation.duration=1;  
    //是否反转变为原来的属性值  
    animation.autoreverses=YES;  
    //把animation添加到图层的layer中,便可以播放动画了。forKey指定要应用此动画的属性  
    [self.view.layer addAnimation:animation forKey:@"backgroundColor"];  
      
}  

2.2 CAKeyframeAnimation

1. path

这是一个 CGPathRef 对象,默认是空的,当我们创建好CAKeyframeAnimation的实例的时候,可以通过制定一个自己定义的path来让 某一个物体按照这个路径进行动画。这个值默认是nil 当其被设定的时候 values 这个属性就被覆盖

2. values

一个数组,提供了一组关键帧的值, 当使用path的 时候 values的值自动被忽略。

-(void)animationOfCAKeyframeAnimation  
{  
    CAKeyframeAnimation *animation=[CAKeyframeAnimation animation];  
    //设置属性值  
    animation.values=[NSArray arrayWithObjects:  
                      (id)self.view.backgroundColor,  
                      (id)[UIColor yellowColor].CGColor,  
                      (id)[UIColor greenColor].CGColor,  
                      (id)[UIColor blueColor].CGColor,nil];  
    animation.duration=3;  
    animation.autoreverses=YES;  
    //把关键帧添加到layer中  
    [self.view.layer addAnimation:animation forKey:@"backgroundColor"];  
}  
-(void)animationOfCAKeyframeAnimationPath  
{  
    //初始化一个View,用来显示动画  
    UIView *redView=[[UIView alloc]initWithFrame:CGRectMake(10, 10, 20, 20)];  
    redView.backgroundColor=[UIColor redColor];  
      
    [self.view addSubview:redView];  
      
    CAKeyframeAnimation *ani=[CAKeyframeAnimation animation];  
    //初始化路径  
    CGMutablePathRef aPath=CGPathCreateMutable();  
    //动画起始点  
    CGPathMoveToPoint(aPath, nil, 20, 20);  
    CGPathAddCurveToPoint(aPath, nil,   
                          160, 30,//控制点  
                          220, 220,//控制点   
                          240, 380);//控制点  
      
    ani.path=aPath;  
    ani.duration=10;  
    //设置为渐出  
    ani.timingFunction=[CAMediaTimingFunction functionWithName:kCAMediaTimingFunctionEaseIn];  
    //自动旋转方向  
    ani.rotationMode=@"auto";  
      
    [redView.layer addAnimation:ani forKey:@"position"];  
}  

2.3 CATransition

代码来自ios 动画效果CATransition笔记

setType:有四种类型:
    kCATransitionFade                   //交叉淡化过渡
    kCATransitionMoveIn               //移动覆盖原图
    kCATransitionPush                    //新视图将旧视图推出去
    kCATransitionReveal                //底部显出来
-(void) changeUIView2{  
   CATransition *transition = [CATransition animation];  
    transition.delegate = self;  
    transition.duration = 2.0f;  
    transition.timingFunction = [CAMediaTimingFunction functionWithName:kCAMediaTimingFunctionEaseIn];  
    transition.type = kCATransitionPush;  
    transition.type = @"pageCurl"  ;//另一种设置动画效果方法  
    transition.subtype = kCATransitionFromBottom;  
    [self.view exchangeSubviewAtIndex:1 withSubviewAtIndex:0];  
    [self.view.layer addAnimation:transition forKey:@"animation"];  
}  

3. 数学层面学习

Core Animation编程指南
这个是一篇国外文章的翻译版本,想深入学习的可以查看原文

4196_131230103956_1.png

4196_131230104111_1.png

4196_131230104316_1.png

4. 实践出真知

...
别瞅了,赶紧行动起来吧
先做个flipboard练练手...

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 214,904评论 6 497
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,581评论 3 389
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 160,527评论 0 350
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,463评论 1 288
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,546评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,572评论 1 293
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,582评论 3 414
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,330评论 0 270
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,776评论 1 307
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,087评论 2 330
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,257评论 1 344
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,923评论 5 338
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,571评论 3 322
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,192评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,436评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,145评论 2 366
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,127评论 2 352

推荐阅读更多精彩内容