使用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 中的动画效果都特别头疼,往往懒得动手,功 ...
随机推荐
- Jquery获得 selection的text 和 option值
Jquery获得 selection的text 和 option值 <select id="accountStatus" editable="false" ...
- JavaEE 配置文件 应用首选项存储
JavaEE 配置文件 应用首选项存储 @author ixenos 什么是首选项? 首选项Preferences 指配置信息 首选项存储就是指对配置信息的存储 有什么方式存储? 有两种,一种存于 ...
- HTTP运行时与页面执行模型
注:本文为个人学习摘录,原文地址:http://www.cnblogs.com/stwyhm/archive/2006/08/09/471765.html HTTP运行时 HTTP运行期处理客户端应用 ...
- JVM基础(4)-编译
一.编译过程 不论是物理机还是虚拟机,大部分的程序代码从开始编译到最终转化成物理机的目标代码或虚拟机能执行的指令集之前,都会按照如下图所示的各个步骤进行: (其中绿色的模块可以选择性实现.) 很容易看 ...
- 记2016商大ACM省赛
比赛前三天才得到省赛的非正式参赛名额,总有点哭笑不得,笑的是是我的终究是我的,跑不掉…… 哭的是现在就剩三天了,虽然最近也一直在参加训练赛,但一直是断断续续的,对自己现在的水平并没有太大的信心…… 虽 ...
- c#设计模式-单例模式(面试题)
c#设计模式-单例模式 单例模式三种写法: 第一种最简单,但没有考虑线程安全,在多线程时可能会出问题, public class Singleton { private static Singleto ...
- Android:OpenFire 相关API (持续更新)
基于XMPP协议的聊天服务器.最近会一直更新相关的API. 需要的软件:OpenFire(服务器),Spark(客户端--测试用),Asmack(Jar包) 1.连接服务器的代码 private vo ...
- 十七、oracle 权限
一.介绍这一部分我们主要看看oracle中如何管理权限和角色,权限和角色的区别在哪里.当刚刚建立用户时,用户没有任何权限,也不能执行任何操作.如果要执行某种特定的数据库操作,则必须为其授予系统的权限: ...
- HDU2544-最短路(最短路模版题目)
Problem Description 在每年的校赛里,所有进入决赛的同学都会获得一件很漂亮的t-shirt.但是每当我们的工作人员把上百件的衣服从商店运回到赛场的时候,却是非常累的!所以现在他们想要 ...
- UVALive 7070 The E-pang Palace(暴力)
实话说这个题就是个暴力,但是有坑,第一次我以为相含是不行的,结果WA,我加上相含以后还WA,我居然把这两个矩形的面积加在一块了吗,应该取大的那一个啊-- 方法就是枚举对角线,为了让自己不蒙圈,我写了一 ...