子类CALayer上自定义属性改变执行的动画和对个人对动画的理解

个人对动画的理解:CALayer的属性变化了,如果添加了动画事务,就会在屏幕上显现了动画,而动画的根本原理是,当你设置了动画的fromValue,duration等数据时候,其实是设置了CALayer的相应属性在presentationLayer的变化数据(变化需要的时间,变化的起始点等),然后每次CALayer的相应属性变化,都会触发drawInContex之类的绘图方法中用新的相应属性值重新绘图。说白了:

                              动画是CALayer属性的变化数据。

所以形成动画需要两个要求:1.属性有不断变化的数据;2.属性可以在绘图函数不断被重新绘制。

注意:动画跟修改CALayer内部属性逐渐变换是不一样的,动画修改的是presentationLayer的数据,修改CALayer内部属性逐渐变换是修改modelLayer的数据。presentationLayer 是CALayer眼睛看到屏幕上CALayer的位置,而实际上CALayer还在modelLayer位置上。这也就是为什么动画结束后,如果不使用下面的代码,CALayer还会回到原来位置,因为modelLayer的数据并没有修改。所以使用下面代码或者强制修改modelLayer的数据,CALayer就不会动画结束后跳回去了。

animation.fillMode = kCAFillModeForward;

animation.removedOnCompletion =NO;

removedOnCompletion 表示动画结束后是否要移除动画,NO表示不移除。

fillMode 表示动画停止时,动画展现在哪里,可以向前展现(动画结束时),向后展现(动画开始时),或者两者都是,或者默认。

注意这个代码并不是修改了modelLayer数据,它只是强制CALayer留在动画最后,所以CALayer和CALayer所在的UIView在屏幕上所看到的位置并不能接收点击事件。

子类CALayer自定义属性的动画:

1.子类CALayer的自定义属性如果是CAShapeLayer,改变CAShapeLayer进行改变时,如缩放,旋转等,会自动动画。CAShapeLayer是CALayer的一个子类,我们使用这个CAShapeLayer相当于使用了CALayer,除了根图层外,子图层的属性都会自动动画,这是隐式动画。

2.如果子类CALayer的自定义属性是其他,如float(CALayer自定义属性不能是对象,否则需要下面注意的处理)等,首先需要屏蔽掉float属性的setter和getter(@dynamic),使用CALayer给float定义的setter方法(这个我们看不见),然后使用+needsDisplayForKey方法,告诉runtime这个float属性改变时,需要重新调用CALayer的-display方法,此时修改float属性 并不会触发动画(因为float属性并没有设置动画,即变化数据),我们需要使用-(id)actionForKey:方法里面定义float的动画(也就是上面说的float的变化数据)。这样就实现了对一个子类CALayer自定义属性的动画,由此可以推测CALayer的属性变化产生的动画都是由-(id)actionForKey:来注册,使用+needsDisplayForKey触发display来更新帧。

注意:

在drawInContex之类的绘图方法中,尽量避免CGContextDrawImageInRect之类的元绘图调用,因为这些元绘图操作非常耗时,也是硬件加速帮不上忙的地方,尽量通过将CGImageRef传给CALayer.contents属性的方法把内容事先做好传给CALayer,然后通过仿射或者3D transform的方法来进行动画变换,  因为仿射或者3D transform是完全硬件加速的,它比自己书写绘图代码要快的多的多  。

layer方法响应链有三种:

1. [layer setNeedDisplay] -> [layer displayIfNeed] -> [layer display] -> [layerDelegate displayLayer:]

2. [layer setNeedDisplay] -> [layer displayIfNeed] -> [layer display] -> [layer drawInContext:] -> [layerDelegate drawLayer: inContext:] 

3.[layer setNeedDisplay] -> [layer displayIfNeed] -> [layer display] -> [layer drawInContext:] -> [layerDelegate drawRect:] (这个只有图层树的根图层才有)

子类化CALayer时,有个地方要注意,因为CoreAnimation在生成中间帧的方式,是通过Copy操作生成了一大堆中间帧用的CALayer,它在复制CALayer的数据时,只能对CALayer原有的属性成员进行copy,不会copy后添加的诸如对象引用一类的东西,这就需要程序员重载(这也就是Layer 中自定义属性的动画这篇博文中,第二个例子不用NSDate的原因)

- (id)initWithLayer:(id)layer

{

       self= [super initWithLayer:layer];

       if(self != nil) {

         MyLayer *myLayer= (MyLayer*)layer;

        self.aUIImage=cl.aUIImage;

      }

   return (self);

}


引用文章:

CALayer的needsDisplayForKey方法使用说明

Layer 中自定义属性的动画

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 206,214评论 6 481
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 88,307评论 2 382
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 152,543评论 0 341
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 55,221评论 1 279
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 64,224评论 5 371
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 49,007评论 1 284
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 38,313评论 3 399
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,956评论 0 259
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 43,441评论 1 300
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,925评论 2 323
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 38,018评论 1 333
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,685评论 4 322
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 39,234评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 30,240评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,464评论 1 261
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 45,467评论 2 352
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,762评论 2 345

推荐阅读更多精彩内容

  • 在iOS中随处都可以看到绚丽的动画效果,实现这些动画的过程并不复杂,今天将带大家一窥iOS动画全貌。在这里你可以看...
    F麦子阅读 5,094评论 5 13
  • 在iOS中随处都可以看到绚丽的动画效果,实现这些动画的过程并不复杂,今天将带大家一窥ios动画全貌。在这里你可以看...
    每天刷两次牙阅读 8,465评论 6 30
  • 如果想让事情变得顺利,只有靠自己--夏尔·纪尧姆 上一章介绍了隐式动画的概念。隐式动画是在iOS平台创建动态用户界...
    夜空下最亮的亮点阅读 1,925评论 0 1
  • 我一直以为所有的事情都会按照自己的想法走,所以自己为了心里的那一个梦不断地做着,努力着。 以为自己做了一个真实的梦...
    格利普阅读 169评论 0 0
  • “爸爸妈妈吵架的时候,你是什么感觉?” “想死的感觉……” 这是父母与孩子间的真实对话。 作为父母,我们了解多少这...
    麦肯兮君阅读 521评论 3 0