(CAPropertyAnimation、CABasicAnimation、CAKeyframeAnimation、CAAnimationGroup介绍)

来源:互联网 发布:iphone纪念日软件 编辑:程序博客网 时间:2024/05/13 19:56

<iframe id="cpro_u2392861_iframe" src="http://pos.baidu.com/hcpm?sz=300x250&amp;rdid=2392861&amp;dc=2&amp;di=u2392861&amp;dri=0&amp;dis=0&amp;dai=1&amp;ps=616x1412&amp;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&amp;dcb=BAIDU_SSP_define&amp;dtm=HTML_POST&amp;dvi=0.0&amp;dci=-1&amp;dpt=none&amp;tsr=0&amp;tpr=1474453614129&amp;ti=%28CAPropertyAnimation%E3%80%81CABasicAnimation%E3%80%81CAKeyframeAnimation%E3%80%81CA&amp;ari=2&amp;dbv=0&amp;drs=3&amp;pcs=1423x628&amp;pss=1423x3350&amp;cfv=23&amp;cpl=9&amp;chi=1&amp;cce=true&amp;cec=UTF-8&amp;tlm=1474453614&amp;rw=628&amp;ltu=http%3A%2F%2Fblog.csdn.net%2FERIC_Dream%2Farticle%2Fdetails%2F47839903&amp;ltr=http%3A%2F%2Fblog.csdn.net%2Flongshihua%2Farticle%2Fdetails%2F46672657&amp;ecd=1&amp;psr=1440x900&amp;par=1440x873&amp;pis=-1x-1&amp;ccd=24&amp;cja=false&amp;cmi=10&amp;col=zh-CN&amp;cdo=-1&amp;tcn=1474453614&amp;qn=00072cf26ca6fb87&amp;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"></iframe>
关闭

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

0 0
原创粉丝点击