说说Core Animation
前言
本次分享将从以下方面进行展开:
- 曾被面试官问倒过的问题:层与视图的关系
CALayer
类介绍及层与视图的关系CAShapeLayer
类介绍UIBezierPath
贝塞尔曲线讲解CoreAnimation
之动画子类介绍CATransitionAnimation
类实现各种过滤动画
关于Core Animation
在iOS
系统中的关系图如下:
可以看出,Core Animation
是相对上层的封装,介于UIKit
与Core Graphics
、OpenGL/OpenGL ES
之间。最底下还有一个Graphics Hardware
,就是硬件了!!!
层与视图的关系
我们先看看Window
与Layer
之间的关系:
这个图告诉我们,层是基于绘画模型实现的,层并不会在我们的app
中做什么事,实际上是层只是捕获app
所提供的内容,并缓存成bitmap
,当任何与层关联的属性值发生变化时,Core Animation
就会将新的bitmap
传给绘图硬件,并根据新的位图更新显示。
UIView
是iOS
系统中界面元素的基础,所有的界面元素都是继承自UIView
。它本身完全是由CoreAnimation
来实现的。它真正的绘图部分,是由一个CALayer
类来管理。UIView
本身更像是一个CALayer
的管理器,访问它的跟绘图和跟坐标有关的属性,例如frame
、bounds
等,实际上内部都是在访问它所包含的CALayer
的相关属性。
提示:
layer-based drawing
不同于view-based drawing
,后者的性能消耗是很高的,它是在主线程上直接通过CPU
完成的,而且通常是在-drawRect:
中绘制动画。
UIView与CALayer的联系
我们看看UIView
与layer
之间的关系图:
我们可以看到,一个UIView
默认就包含一个layer
属性,而layer
是可以包含sublayer
的,因此形成了图层树。从此图可以看出这两者的关系:视图包含一个layer
属性且这个layer
属性可以包含很多个sublayer
。
有人说UIView
就像一个画板,而layer
就像画布,一个画板上可以有很多块画布,但是画布不能有画板。
UIView与CALayer的主要区别
UIView
是可以响应事件的,但是CALayer
不能响应事件UIView
主要负责管理内容,而CALayer
主要负责渲染和呈现。如果没有CALayer
,我们是看不到内容的。CALayer
维护着三个layer tree
,分别是presentLayer Tree
、modeLayer Tree
、Render Tree
,在做动画的时候,我们修改动画的属性,其实是修改presentLayer
的属性值,而最终展示在界面上的其实是提供UIView
的modelLayer
。
官方说明了UIView
与CALayer
的联系:
Layers are not a replacement for your app’s views—that is, you cannot create a visual interface based solely on layer objects. Layers provide infrastructure for your views. Specifically, layers make it easier and more efficient to draw and animate the contents of views and maintain high frame rates while doing so. However, there are many things that layers do not do. Layers do not handle events, draw content, participate in the responder chain, or do many other things. For this reason, every app must still have one or more views to handle those kinds of interactions.
说说CALayer
我们首先得明确Layer
在iOS
系统上的坐标系起点是在左上角的,而在OS X
系统上是左下角的:
笔者对Layer
相关的属性和方法画了这么一张图:
看看官方关于Layer Tree
的说明:
关于这一节,请阅读iOS CALayer解读,文章末尾有Demo可以下载运行看效果。
说说UIBezierPath
关于这一节,请阅读iOS UIBezierPath解读,文章末尾有Demo可以下载运行看效果。
说说CAShapeLayer
关于这一节,请阅读iOS CAShapeLayer解读,文章末尾有Demo可以下载运行看效果。
Core Animation介绍
我们在开发中常见的动画:
笔者将Core Animation
的关系图及相关属性、方法说明都通过该图来表达:
如果我们要改变动画的行为,我们可以实现CAAction
协议的方法,像这样:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
|
- (id<CAAction>)actionForLayer:(CALayer *)theLayer
forKey:(NSString *)theKey {
CATransition *theAnimation=nil;
if ([theKey isEqualToString:@"contents"]) {
theAnimation = [[CATransition alloc] init];
theAnimation.duration = 1.0;
theAnimation.timingFunction = [CAMediaTimingFunction functionWithName:kCAMediaTimingFunctionEaseIn];
theAnimation.type = kCATransitionPush;
theAnimation.subtype = kCATransitionFromRight;
}
return theAnimation;
}
|
说说Core Animation的更多相关文章
- iOS 图形图像动画 Core Animation
//Core Animation #define WeakSelf __weak __typeof(self) weakSelf = self #define StrongSelf __strong ...
- iOS开发之Core Animation
在IOS中如果使用普通的动画则可以使用UIKit提供的动画方式来实现,如果想实现更复杂的效果,则需要使用Core Animation了. 在Core Animation中我们经常使用的是 CABasi ...
- 老司机带你走进Core Animation
为什么时隔这么久我又回来了呢? 回来圈粉. 开玩笑的,前段时间ipv6被拒啊,超级悲剧的,前后弄了好久,然后需求啊什么的又超多,所以写好的东西也没有时间整理.不过既然我现在回来了,那么这将是一个井喷的 ...
- IOS Core Animation Advanced Techniques的学习笔记(五)
第六章:Specialized Layers 类别 用途 CAEmitterLayer 用于实现基于Core Animation粒子发射系统.发射器层对象控制粒子的生成和起源 CAGradient ...
- IOS Core Animation Advanced Techniques的学习笔记(四)
第五章:Transforms Affine Transforms CGAffineTransform是二维的 Creating a CGAffineTransform 主要有三种变 ...
- IOS Core Animation Advanced Techniques的学习笔记(一)
转载. Book Description Publication Date: August 12, 2013 Core Animation is the technology underlying A ...
- 关于Core Animation(转载部分内容)
读者在浏览技术博客的时候,看到一篇关于Core Animation的介绍,觉得挺有用的,想分享给大家.原作者不知道是谁,嘿,所以就先不标注了,如有冒犯敬请原谅.不过笔者从中摘录部分内容分享一下. 其中 ...
- iOS Core Animation之CALayer心得
使用CALayer的mask实现注水动画效果 Core Animation一直是iOS比较有意思的一个主题,使用Core Animation可以实现非常平滑的炫酷动画.Core animtion的AP ...
- iOS——Core Animation 知识摘抄(四)
原文地址http://www.cocoachina.com/ios/20150106/10840.html 延迟解压 一旦图片文件被加载就必须要进行解码,解码过程是一个相当复杂的任务,需要消耗非常长的 ...
- iOS——Core Animation 知识摘抄(三)
原文地址:http://www.cocoachina.com/ios/20150105/10827.html CAShapeLayer CAShapeLayer是一个通过矢量图形而不是bitmap来绘 ...
随机推荐
- Oracle10 多行和并
SELECT fspc, wmsys.wm_concat (jsrzmc) as jsr FROM dxjsrxx GROUP BY fspc select fspc, LISTAGG(jsrzmc, ...
- 直接用postman测试api ,服务器端没提供跨域也可以访问。
1. 直接用postman测试api ,服务器端没提供跨域也可以访问. 但是,如果用本地的 sever 搭的server, 然后去访问api的话,浏览器会提示 跨域错误.
- 【转】Xshell 十个技巧
原文:http://www.cnblogs.com/wanhl/archive/2012/10/17/2727607.html 一.帐号密码保存.可以保存多个vps登陆信息,免去每次输入的烦恼. 二. ...
- auto_ash
#!/usr/bin/ksh ##############paramter######################startdate=$1' 00:00:01'enddate=$2' 23:59: ...
- 【java】基础中的杂乱总结(二)
1 内部类进阶 package package8; //原则:先用内部类写 之后由于内部类匿名无法引用 用其继承的父类或实现的接口名 //再复写所有的抽象方法即可(是所有,否者还是抽象的,无法创建对象 ...
- 【prim + kruscal 】 最小生成树模板
来源:dlut oj 1105: Zhuo’s Dream Time Limit: 1 Sec Memory Limit: 128 MBSubmit: 40 Solved: 14[Submit][St ...
- 超棒的自定义超酷滚动条jQuery插件 - Perfect Scrollbar
可能大家厌倦了千篇一律的页面滚动条,如果你希望能够设计出与众不同的页面UI设计的话,Perfect ScrollBar可能就是你寻找的解决方案. 这个滚动条来自于一个个人项目,一个简单但是非常棒的滚动 ...
- poi 合并单元格、设置边框
HSSFWorkbook wb = new HSSFWorkbook(); HSSFSheet sheet = wb.createSheet(); //创建一个样式 HSSFCellStyle sty ...
- POJ 2031 Building a Space Station 最小生成树模板
题目大意:在三维坐标中给出n个细胞的x,y,z坐标和半径r.如果两个点相交或相切则不用修路,否则修一条路连接两个细胞的表面,求最小生成树. 题目思路:最小生成树树模板过了,没啥说的 #include& ...
- openwrt+ndp+ndppd+radvd+dhcpv6,ipv6穿透配置指南
要用ipv6首先你的openwrt路由内核必须已经支持ipv6,且能安装相关软件! 首先说说最简单的ndp手工ipv6穿透,很简单,看代码详解: 环境: wan口 eth1 lan口 br-lan w ...