(CAPropertyAnimation、CABasicAnimation、CAKeyframeAnimation、CAAnimationGroup介绍)

id="cpro_u2392861_iframe" src="http://pos.baidu.com/hcpm?sz=300x250&rdid=2392861&dc=2&di=u2392861&dri=0&dis=0&dai=1&ps=616x1412&coa=at%3D3%26rsi0%3D300%26rsi1%3D250%26pat%3D17%26tn%3DbaiduCustNativeAD_xuanfu%26rss1%3D%2523FFFFFF%26conBW%3D1%26adp%3D1%26ptt%3D0%26titFF%3D%2525E5%2525BE%2525AE%2525E8%2525BD%2525AF%2525E9%25259B%252585%2525E9%2525BB%252591%26titFS%3D14%26rss2%3D%2523000000%26titSU%3D0&dcb=BAIDU_SSP_define&dtm=HTML_POST&dvi=0.0&dci=-1&dpt=none&tsr=0&tpr=1474453614129&ti=%28CAPropertyAnimation%E3%80%81CABasicAnimation%E3%80%81CAKeyframeAnimation%E3%80%81CA&ari=2&dbv=0&drs=3&pcs=1423x628&pss=1423x3350&cfv=23&cpl=9&chi=1&cce=true&cec=UTF-8&tlm=1474453614&rw=628&ltu=http%3A%2F%2Fblog.csdn.net%2FERIC_Dream%2Farticle%2Fdetails%2F47839903&ltr=http%3A%2F%2Fblog.csdn.net%2Flongshihua%2Farticle%2Fdetails%2F46672657&ecd=1&psr=1440x900&par=1440x873&pis=-1x-1&ccd=24&cja=false&cmi=10&col=zh-CN&cdo=-1&tcn=1474453614&qn=00072cf26ca6fb87&tt=1474453614111.20.21.22" vspace="0" hspace="0" marginwidth="0" marginheight="0" scrolling="no" style="border-width: 0px; border-style: initial; vertical-align: bottom; margin: 0px;" allowtransparency="true" frameborder="0" height="250" align="center,center" width="300">
关闭

CAPropertyAnimation:

1,是CAAnimation的子类,也是个抽象类。要想创建动画,应该使用它的两个子类:CABasicAnimation和CAKeyframeAnimation

2,属性解析:

keyPath:通过指定CALayer的一个属性名,并且对CALayer的这个属性的值进行修改,达到相应的效果。

比如:keyPath = @”position”;我们就可以修改CALayer的position属性的值,以达到平移的动画效果。

CABasicAnimation:

1,是CAPropertyAnimation的子类

2,属性解析:

fromValue:keyPath相应属性的初始值

toValue:keyPath相应属性的结束值

随着动画的进行,在长度为duration的持续时间内,keyPath相应属性的值从fromValue渐渐地变成toValue

3,如果fillMode=kCAFillModeForwards和removedOnComletion=NO,那么在动画执行完毕后,图层会保持显示动画执行后的状态。但在实质上,图层的属性值还是动画执行前的初始值,并没有真正被改变。比如,CALayer的position初始值为(0,0),CABasicAnimation的fromValue为(10,10),toValue为(100,100),虽然动画执行完毕后图层保持在(100,100)这个位置,实质上图层的position还是为(0,0)

CAKeyframeAnimation:

1,CAPropertyAnimation的子类,跟CABasicAnimation的区别是:

CABasicAnimation只能从一个数值(fromValue)变到另一个数值(toValue),

而CAKeyframeAnimation会使用一个NSArray保存这些数值

2,属性解析:

values:

就是上述的NSArray对象。里面的元素称为”关键帧”(keyframe)。动画对象会在指定的时间(duration)内,依次显示values数组中的每一个关键帧

path:

可以设置一个CGPathRef\CGMutablePathRef,让层跟着路径移动。path只对CALayer的anchorPoint和position起作用。如果你设置了path,那么values将被忽略

keyTimes:

可以为对应的关键帧指定对应的时间点,其取值范围为0到1.0,keyTimes中的每一个时间值都对应values中的每一帧.当keyTimes没有设置的时候,各个关键帧的时间是平分的

CABasicAnimation可看做是最多只有2个关键帧的CAKeyframeAnimation

CAAnimationGroup:

1,CAAnimation的子类,可以保存一组动画对象,将CAAnimationGroup对象加入层后,组中所有动画对象可以同时并发运行

2,属性解析:

animations:用来保存一组动画对象的NSArray

默认情况下,一组动画对象是同时运行的,也可以通过设置动画对象的beginTime属性来更改动画的开始时间



http://blog.csdn.net/ERIC_Dream/article/details/47839903

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值