对UIView动画和Core Animation的关系的一点理解
2016-08-11 08:30
211 查看
http://www.jianshu.com/p/72f4cca98b0e
1、UIView动画是应用在一个view上面的,一种是使用CATransition进行更低层次的控制,UIView方式可能在低层也是使用CATransition进行了封装。2、CABasicAnimation动画是应用在一个layer上面的。
在iOS开发的时候,如果想给用户界面加入一些简单的动画,那UIView动画一定是很多人的首选。因为它写起来非常简洁,只需要把将要改变的property值放入UIView的animation block中,比如:
[UIView animateWithDuration:5.0 animations:^{ myView.alpha = 0.5; }];
但是我也一直疑惑,这样的写法,和使用CAAnimation有什么不同呢?有人说,UIView动画只是把Core Animation的一些操作封装了起来。虽然我也这么猜测,但是我打算写代码验证一下。
根据这篇苹果官方文档,我们可以得知,每一个view.layer都以该view作为其delegate,并通过询问view的
actionForLayer:forKey:方法来获得自己应该执行的CAAction对象。
所以我自定义了一个XSQView类,继承自UIView,仅仅重写了其中的
actionForLayer:forKey:方法:
- (id<CAAction>)actionForLayer:(CALayer *)layer forKey:(NSString *)event { id<CAAction> action = [super actionForLayer:layer forKey:event]; NSLog(@"action for layer: %@, for key:%@ is %@", layer, event, action); return action; }
用于观察UIView对它的layer提供了什么样的CAAction对象。
用UIView动画改变XSQView对象的property,比如:
[UIView animateWithDuration:5.0 animations:^{ xsqView.alpha = 0.5; }];
可以发现,此时,XSQView中的
actionForLayer:forKey:方法被多次调用,产生了这样的输出:
2015-04-06 11:59:21.373 AnimationDemo[1023:44875] action for layer: <CALayer: 0x7fa952413150>, for key:bounds is <null> 2015-04-06 11:59:21.374 AnimationDemo[1023:44875] action for layer: <CALayer: 0x7fa952413150>, for key:opaque is <null> 2015-04-06 11:59:21.375 AnimationDemo[1023:44875] action for layer: <CALayer: 0x7fa952413150>, for key:position is <null> 2015-04-06 11:59:21.375 AnimationDemo[1023:44875] action for layer: <CALayer: 0x7fa952413150>, for key:onOrderIn is <null> 2015-04-06 11:59:21.408 AnimationDemo[1023:44875] action for layer: <CALayer: 0x7fa952413150>, for key:opacity is <CABasicAnimation: 0x7fa95275bc20>
<null>是
[NSNull null]的输出。说明对于其他的几种key,UIView对象告诉它的layer,停止对CAAction对象的搜索。而对opacity这个key,UIView对象则给出了一个CABasicAnimation对象。
打印这个CABasicAnimation对象的部分信息,发现这可能就是由UIView animation block中的代码转换出的CAAnimation。
<CABasicAnimation:0x7fa95275bc20; delegate = <UIViewAnimationState: 0x7fd811c376b0>; fillMode = both; timingFunction = easeInEaseOut; duration = 5; fromValue = 1; keyPath = opacity>
(但是这个CABasicAnimation中的toValue和byValue都是nil)
另外,用类似的方式观察layer对象的行为(根据苹果官方文档,可以通过重载UIView中的
layerClass方法来改变这个View使用的layer的类型。所以自定义一个CALayer的子类作为view的layerClass,并重写CALayer的部分方法起到监控CALayer行为的目的。),我发现layer的
addAnimation:forKey:方法也被调用了,这个CABasicAnimation对象被加入到了layer中。
如果在UIView的animation block中,改变了一个view的多个property,则会有多个CAAnimation对象被加入到layer中。
我觉得到这里已经能表明,UIView动画其实就是对Core Animation的一种封装,向客户程序员呈现更简洁的接口。
但是我也发现了,在UIView的animation block中改变position或者bounds等属性,会有一些特别的行为。因为这些属性可能对应着多个animation key。所以,从
actionForLayer:forKey:中返回的对象也不是一个CAAnimation对象了,而是一个(没有公开的)
_UIViewAdditiveAnimationAction对象。随后,可能有多个CAAnimation对象被加入到layer中。
相关文章推荐
- 对UIView动画和Core Animation的关系的一点理解
- 有关WLAN与wifi、WPAN与Bluetooth、WPAN与802.15、wifi与802.11、WiMAX与802.16等关系的一点理解
- [转载+实践理解]Android动画---如何正确使用平移动画(关于fillBefore和fillAfter的一点说明)(转载)
- UIViewAnimation动画与Core Animation的CATransition类动画
- UIView中视图关系分析以及视图跳转动画的使用
- UIView动画与core animation之间的关系
- ios 对于UIView的动画的初步理解
- 理解redo(8)redo和undo的一点关系及删除联机日志文件组的注意事项
- iOS学习笔记59-UIView自带动画和核心动画(Core Animation)
- 有关WLAN与wifi、WPAN与Bluetooth、WPAN与802.15、wifi与802.11、WiMAX与802.16等关系的一点理解
- 对骨骼动画的一点理解
- iOS中的动画:核心动画Core Animation, UIView动画, Block动画, UIImageView的帧动画.
- 有关WLAN与wifi、WPAN与Bluetooth、WPAN与802.15、wifi与802.11、WiMAX与802.16等关系的一点理解
- 关于BMP图片的一点理解,读取图象数据到数组
- Transaction 和 DataAccess的关系得一点想法
- 对grub的一点理解
- java设计中深入理解abstract class和interface之间的关系
- 关于equals()和==操作的一点理解
- 手机中文码制问题的一点理解【转载】
- 关于日期显示格式字符串的一点理解