使用Core Animation对象来实现动画
转载保留原文地址:http://blog.csdn.net/kqjob/article/details/10417461,转载的
在iOS中如果使用普通的动画则可以使用UIKit提供的动画方式来实现,如果想实现更复杂的效果,则需要使用Core Animation了。
下面详解各种类型动画的使用方式
1、通过动画上下文使用UIKit动画
- -(void)animationOfUIKit
- {
- UIView *redView=[[UIView alloc]initWithFrame:CGRectMake(10, 10, 100, 100)];
- redView.backgroundColor=[UIColor redColor];
- [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];
- }
2、通过代码块使用UIKit动画
- -(void)animationOfBlock
- {
- //初始化一个View,用来显示动画
- UIView *redView=[[UIView alloc]initWithFrame:CGRectMake(10, 10, 100, 100)];
- redView.backgroundColor=[UIColor redColor];
- [self.view addSubview:redView];
- [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){
- //动画结束时调用
- //............
- }];
- }
使用Core Animation对象来实现动画
在Core Animation中我们经常使用的是
- CABasicAnimation
- CAKeyframeAnimation
- CATransitionAnimation
其中CABasicAnimation和CAKeyframeAnimation是对图层中的不同属性进行动画的。
如果要多整个图层进行动画,则应该使用CATransitionAnimation
如果要使用组合动画,例如要改变图层的大小和透明度,则可以先为每个属性创建一个CABasicAnimation对象,再把他们组合到CAAnimationGroup中,最后把这个组合添加到要进行动画的CALayer中。
注:CAAnimation(以及CAAnimation的子类),全部都是显式动画,这样动画播放后,表现层回恢复到模型层的原始状态,这就意味着,如果动画播放完后,会恢复到原来的样子,所以在动画播放完后要对模型层进行修改,例如:self.view.layer.backgroundColor=[UIColor blueColor].CGColor;
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、关键帧动画:CAKeyframeAnimation
1. path
这是一个 CGPathRef 对象,默认是空的,当我们创建好CAKeyframeAnimation的实例的时候,可以通过制定一个自己定义的path来让 某一个物体按照这个路径进行动画。这个值默认是nil 当其被设定的时候 values 这个属性就被覆盖
2. values
一个数组,提供了一组关键帧的值, 当使用path的 时候 values的值自动被忽略。
下面是改变依次改变view的颜色
- -(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"];
- }
3、使用路径制作动画:CAKeyframeAnimation
- -(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"];
- }
使用Core Animation对象来实现动画的更多相关文章
- iOS Core Animation学习总结(3)--动画的基本类型
一. CABasicAnimation (基础动画) 移位: CABasicAnimation *animation = [CABasicAnimation animation]; //keyPath ...
- core Animation之CAKeyframeAnimation(关键帧动画)
CABasicAnimation的区别是:CABasicAnimation只能从一个数值(fromValue)变到另一个数值(toValue),而CAKeyframeAnimation会使用一个NSA ...
- Core Animation中的组动画
实际开发中一个物体的运动往往是复合运动,单一属性的运动情况比较少,但恰恰属性动画每次进行动画设置时一次只能设置一个属性进行动画控制(不管是 基础动画还是关键帧动画都是如此),这样一来要做一个复合运动的 ...
- Core Animation之CABasicAnimation(基础动画)
#import "ViewController.h" @interface ViewController () @property(nonatomic,strong)UIButto ...
- Core Animation中的关键帧动画
键帧动画就是在动画控制过程中开发者指定主要的动画状态,至于各个状态间动画如何进行则由系统自动运算补充(每两个关键帧之间系统形成的动画称为“补间动画”),这种动画的好处就是开发者不用逐个控制每个动画帧, ...
- Core Animation中的基础动画
基础动画 在开发过程中很多情况下通过基础动画就可以满足开发需求,前面例子中使用的UIView代码块进行图像放大缩小的演示动画也是基础动画(在iOS7 中UIView也对关键帧动画进行了封装),只是UI ...
- 在ios中运用core animation暂停和继续动画
本文转载至 http://blog.csdn.net/wildfireli/article/details/23191861 暂停和继续动画的核心代码如下: <pre name="co ...
- IOS动画(Core Animation)总结 (参考多方文章)
一.简介 iOS 动画主要是指Core Animation框架.官方使用文档地址为:Core Animation Guide. Core Animation是IOS和OS X平台上负责图形渲染与动画的 ...
- iOS 动画效果:Core Animation & Facebook's pop
本文转载至 http://www.cocoachina.com/ios/20151223/14739.html 感谢原创作者分享 前言相信很多人对实现 iOS 中的动画效果都特别头疼,往往懒得动手,功 ...
随机推荐
- 设计模式 单例模式(Singleton) [ 转载 ]
设计模式 单例模式(Singleton) [ 转载 ] 转载请注明出处:http://cantellow.iteye.com/blog/838473 前言 懒汉:调用时才创建对象 饿汉:类初始化时就创 ...
- 二分法经典习题——HDU1969
#include <iostream>#include <cmath>#include <iomanip>using namespace std; double p ...
- 转 delphi SelText,GetText,SetText用法
转自:http://blog.163.com/wll_009/blog/static/1173731172009102452632968/ 这几个都跟选区有关的,就是选中一串字符串,选中的会变蓝色Se ...
- delphi中nil、null、UnAssigned区别
nil:空指针,空地址,对象也是指针,所以可以object := nil;null:null是一个未定义值的变量,既不是0也不代表空字符串,它是未定义的.http://www.delphibasics ...
- MVC3+EF4.1学习系列(八)-----利用Repository and Unit of Work重构项目
项目最基础的东西已经结束了,但是现在我们的项目还不健全 不利于测试 重复性代码多 层与层之间耦合性高 不利于扩展等问题.今天的这章 主要就是解决这些问题的.再解决这些问题时,自己也产生了很多疑 ...
- [kuangbin带你飞]专题四 最短路练习 POJ 2253 Frogger
求第一个点到第二个点的所有通路上最长的边 dijkstra的变形 每次松弛的是每条边通路上的的最长的边 WA了好几次是因为用了%lf 改成%f就过了…… /* ******************** ...
- C#整理 条件语句
条件语句主要分为if else语句和switch case语句. if else语句主要分为四种格式: 1. if(表达式) {} 2.二选一 if(表达式) {} else {} 3.多选一 if( ...
- POJ 2536 Gopher II
二分图的最大匹配 地鼠内部和地鼠洞内部都是没有边相连的,那么就可以看成一个二分图.地鼠如果可以跑到那个地鼠洞,就连一条边,然后跑二分图的最大匹配,最后地鼠的数量减去最大匹配数就是答案. #includ ...
- C++中复制构造函数和赋值操作符
先看一个例子: 定义了一个类:
- MYSQL超时连接问题(com.mysql.jdbc.MysqlIO.readFully)
应用服务器连接mysql,有时候会出现以下异常: at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.jav ...