CALayer --> UIView
一、CALayer和UIView的关系
- UIView显示在屏幕上归功于CALayer
可以说:UIView依赖CALayer,又高于CALayer
通过调用drawRect方法来渲染自身的内容,调节CALayer属性可以调整UIView的外观,UIView继承自UIResponder,比起CALayer可以响应用户事件,Xcode6之后可以方便的通过视图调试功能查看图层之间的关系
2.UIView更像是一个CALayer的管理器
UIView是iOS系统中界面元素的基础,所有的界面元素都继承自它。
它内部是由Core Animation来实现的,它真正的绘图部分,是由一个叫CALayer(Core Animation Layer)的类来管理。UIView本身,更像是一个CALayer的管理器,访问它的跟绘图和坐标有关的属性,如frame,bounds等,实际上内部都是访问它所在CALayer的相关属性
3.layer属性,layerClass方法
UIView有个layer属性,可以返回它的主CALayer实例,
UIView有一个layerClass方法,返回主layer所使用的类,UIView的子类,可以通过重载这个方法,来让UIView使用不同的CALayer来显示,如:
- (class) layerClass {
// 使某个UIView的子类使用GL来进行绘制
return ([CAEAGLLayer class]);
}
4.layer上添加子layer
UIView的CALayer类似UIView的子View树形结构,也可以向它的layer上添加子layer,来完成某些特殊的显示。
例如下面的代码会在目标View上敷上一层黑色的透明薄膜。
grayCover = [[CALayer alloc]init];
grayCover.backgroudColor = [[UIColor blackColor]colorWithAlphaComponent:0.2].CGColor;
[self.layer addSubLayer:grayCover];
5.补充部分,UIView的layer树形在系统内部被系统维护着三份copy
- 这三棵树的逻辑结构都是一样的,区别只有各自的属性
- 1.逻辑树,就是代码里可以操纵的,例如更改layer的属性等等就在这一份
- 2.动画树,这是一个中间层,系统正是在这一层上更改属性,进行各种渲染操作
- 3.显示树,这棵树的内容是当前正被显示在屏幕上的内容
1. 其实UIView之所以能显示在屏幕上,完全是因为它内部的一个图层(即CALayer对象)
2. 换句话说,UIView本身不具备显示的功能,是它内部的层才有显示功能
3.在创建UIView对象时,UIView内部会自动创建一个图层(即CALayer对象),通过UIView的layer属性可以访问这个层
@property(nonatomic,readonly,retain)CALayer*layer;
4. 当UIView需要显示到屏幕上时
4.1 会调用drawRect:方法进行绘图,并且会将所有内容绘制在自己的图层layer属性上
4.2 绘图完毕后,系统会将图层拷贝到屏幕上,于是就完成了UIView的显示
二、UIView和CALayer的选择
既然CALayer和UIView都能实现相同的显示效果,那究竟该选择谁好呢?
UIView:
- 对比CALayer,UIView多了一个事件处理的功能。也就是说,CALayer不能处理用户的触摸事件,选择UIView
CALayer:不用处理用户交互,UIView与CALayer都可以,而选择CALayer,性能会高一些,因为少了事件处理的功能,更加轻量级相比UIView。
总结:
- 如果显示出来的东西需要跟用户进行交互的话,用UIView;如果不需要跟用户进行交互,用UIView或者CALayer都可以
三、CALayer
1.拿到view对象的layer属性,我们能做什么?
- 可以很方便的调整view的外观属性:阴影、圆角大小、边框宽度和颜色.......
- 而且,我们还可以给图层添加动画
CALayer是定义在
Core Animation框架中
的
- CA开头,CALayer,Core Animation
QuartzCore
:专指Core Animation用到的动画相关的库、API和类- 顺便复习一下:Quartz2D它是二维绘图引擎,它是依赖Core Graphics框架的API和类
CGImageRef、CGColorRef两种数据类型是定义在CoreGraphics框架中的,以CG开头,UIColor是定义在UIKit框架中的
QuartzCore框架和CoreGraphics框架是可以跨平台使用的,在iOS和Mac OS X上都能使用
Ø但是UIKit只能在iOS中使用
四、CALayer的基本属性
// 宽度和高度
@propertyCGRectbounds;
// 位置(默认指中点,具体由anchorPoint决定)
@propertyCGPointposition;
// 锚点(x,y的范围都是0-1),决定了position的含义
@propertyCGPointanchorPoint;
// 背景颜色(CGColorRef类型)
@propertyCGColorRefbackgroundColor;
// 形变属性
@propertyCATransform3Dtransform;
// 边框颜色(CGColorRef类型)
@propertyCGColorRefborderColor;
// 边框宽度
@propertyCGFloatborderWidth;
// 圆角半径
@propertyCGColorRefborderColor;
// 内容(比如设置为图片CGImageRef)
@property(retain)idcontents;
CALayer --> UIView的更多相关文章
- CALayer & UIView 关系浅析
原文链接:http://www.jianshu.com/p/8e6a313c158e 一.CALayer和UIView的关系 UIView显示在屏幕上归功于CALayer 可以说:UIView依赖CA ...
- UIView 与 CALayer
联系: 1. UIView 有个属性 layer,可以返回它的主 CALayer 实例:CALayer *layer = myView.layer 2. 一个 UIView 可以有多个 CALayer ...
- UIView详解
MVC架构模式 MVC(Model-View-Controller)是实现数据和显示数据的视图分离的架构模式(有一定规模的应用都应该实现数据和显示的分离).其中,M代表模型,就是程序中使用的数据和 ...
- UIView的剖析(转)
转自:http://blog.csdn.net/mengtnt/article/details/6716289 前面说过UIViewController,但是UIView也是在MVC中非常重要的一层 ...
- CALayer图层的基本介绍
掌握 ● CALayer的基本属性 ● CALayer和UIView的关系 ● position和anchorPoint的作⽤用 CALayer ● 在iOS中,你能看得见摸得着的东西基本上都是UIV ...
- iOS边练边学--CALayer,非根层隐式动画,钟表练习
一.CALayer UIView之所以能显示在屏幕上,完全是因为他内部的一个图层 在创建UIView对象时,UIView内部会自动创建一个图层(即CALayer对象),通过UIView的layer属性 ...
- IOS CALayer基本使用 (图层)
● 其实UIView之所以能显示在屏幕上,完全是因为它内部的一个图层(CALayer) ● 在创建UIView对象时,UIView内部会自动创建一个图层(即CALayer对象),通过UIView 的l ...
- IOS- 02 零碎知识总结
1.UIView,UIViewController,UIWindow和CALayer UIView是什么,做什么:UIView是用来显示内容的,可以处理用户事件 CALayer是什么,做什么:CALa ...
- 彻底理解position与anchorPoint
引言 相信初接触到CALayer的人都会遇到以下几个问题: 为什么修改anchorPoint会移动layer的位置?CALayer的position点是哪一点呢?anchorPoint与positio ...
随机推荐
- 瑞游天翼客户端win7,win8,win10
以管理员身份运行即可, 链接: http://pan.baidu.com/s/1kTw7VH9 密码: vttq
- 使用httperrequest,模拟发送及接收Json请求
使用httpreques\Json-Handle\tcpdump\wireshark工具进行,抓取手机访问网络的包,分析request及response请求,通过httprequester来实现模拟发 ...
- 1213 How Many Tables 简单的并查集问题
my code: #include <cstdio>#include <cstring>#include<iostream>using namespace std; ...
- UIImageView的UserInteractionEnabled什么时候为no
UIImageView作为背景,但直接把按钮或者UITextField放在上面无法相应事件 特殊子类的覆盖 userInteractionEnabled属性默认值为YES,但UIView的一些子类中对 ...
- repeat帮定删除按钮事件,并且生成去人删除提示
前台 <ItemTemplate> <tr> <td> <asp:LinkButton ID="LinkButton_cancel" On ...
- MinGW 运行C++程序的方法
1:安装好 MinGW 及 GCC 编译器后 , 当然 MinGW 全安装最保险了,不会太费劲 2:配置环境变量(注:可能需要重启后生效) 计算机 --> 属性 --> 高级系统设置 -- ...
- .Cannot create an NSPersistentStoreCoordinator with a nil model
今天用coredata事,忽然遇到这个问题:找了一会终于发现问题所在,与大家分享一下 导致这个问题的原因是因为找不到.xcdatamodeld所致,不同的人可能遇到的问题不同 可能原因1: NSURL ...
- PHP运行模式(cgi,fast-cgi,cli, ISAPI ,web模块模式)【转载】
PHP运行模式有5钟: 1)cgi 通用网关接口(Common Gateway Interface))2)fast-cgi 常驻 (long-live) 型的 CGI3)cli 命令行运行 (C ...
- 浅谈 qmake 之 shadow build
shadow build shadow build 是什么东西?就是将源码路径和构建路径分开(也就是生成的makefile文件和其他产物都不放到源码路径),以此来保证源码路径的清洁. 这不是qmake ...
- iOS开发:后台运行以及保持程序在后台长时间运行
第一部分 1.先说说iOS 应用程序5个状态: 停止运行-应用程序已经终止,或者还未启动. 不活动-应用程序处于前台但不再接收事件(例如,用户在app处于活动时锁住了设备). 活动-app处于“使用中 ...