UIView和CALayer之间是什么层级关系?

2026-04-02 14:421阅读0评论SEO问题
  • 内容介绍
  • 文章标签
  • 相关推荐

本文共计394个文字,预计阅读时间需要2分钟。

UIView和CALayer之间是什么层级关系?

UIView显示在屏幕上主要通过CALayer实现功能,通过调用drawRect方法来渲染自身内容,调节CALayer属性可调整UIView外观,UIView继承自UIResponder,与CALayer+UIView相比,UIView在屏幕上的显示功能更依赖于CALayer。

UIView和CALayer之间是什么层级关系?

UIView显示在屏幕上归功于CALayer,通过调用drawRect方法来渲染自身的内容,调节CALayer属性可以调整UIView的外观,UIView继承自UIResponder,比起CALaye
  • UIView显示在屏幕上归功于CALayer,通过调用drawRect方法来渲染自身的内容,调节CALayer属性可以调整UIView的外观,UIView继承自UIResponder,比起CALayer可以响应用户事件,Xcode6之后可以方便的通过视图调试功能查看图层之间的关系
  • UIView是iOS系统中界面元素的基础,所有的界面元素都继承自它。它内部是由Core Animation来实现的,它真正的绘图部分,是由一个叫CALayer(Core Animation Layer)的类来管理。UIView本身,更像是一个CALayer的管理器,访问它的跟绘图和坐标有关的属性,如frame,bounds等,实际上内部都是访问它所在CALayer的相关属性
  • UIView有个layer属性,可以返回它的主CALayer实例,UIView有一个layerClass方法,返回主layer所使用的类,UIView的子类,可以通过重载这个方法,来让UIView使用不同的CALayer来显示,如:
- (class) layerClass { // 使某个UIView的子类使用GL来进行绘制 return ([CAEAGLLayer class]);}
  • UIView的CALayer类似UIView的子View树形结构,也可以向它的layer上添加子layer,来完成某些特殊的显示。例如下面的代码会在目标View上敷上一层黑色的透明薄膜。
grayCover = [[CALayer alloc]init];grayCover.backgroudColor = [[UIColor blackColor]colorWithAlphaComponent:0.2].CGColor;[self.layer addSubLayer:grayCover];
  • 补充部分,这部分有深度了,大致了解一下吧,UIView的layer树形在系统内部被系统维护着三份copy
    • 逻辑树,就是代码里可以操纵的,例如更改layer的属性等等就在这一份
    • 动画树,这是一个中间层,系统正是在这一层上更改属性,进行各种渲染操作
    • 显示树,这棵树的内容是当前正被显示在屏幕上的内容
    • 这三棵树的逻辑结构都是一样的,区别只有各自的属性

本文共计394个文字,预计阅读时间需要2分钟。

UIView和CALayer之间是什么层级关系?

UIView显示在屏幕上主要通过CALayer实现功能,通过调用drawRect方法来渲染自身内容,调节CALayer属性可调整UIView外观,UIView继承自UIResponder,与CALayer+UIView相比,UIView在屏幕上的显示功能更依赖于CALayer。

UIView和CALayer之间是什么层级关系?

UIView显示在屏幕上归功于CALayer,通过调用drawRect方法来渲染自身的内容,调节CALayer属性可以调整UIView的外观,UIView继承自UIResponder,比起CALaye
  • UIView显示在屏幕上归功于CALayer,通过调用drawRect方法来渲染自身的内容,调节CALayer属性可以调整UIView的外观,UIView继承自UIResponder,比起CALayer可以响应用户事件,Xcode6之后可以方便的通过视图调试功能查看图层之间的关系
  • UIView是iOS系统中界面元素的基础,所有的界面元素都继承自它。它内部是由Core Animation来实现的,它真正的绘图部分,是由一个叫CALayer(Core Animation Layer)的类来管理。UIView本身,更像是一个CALayer的管理器,访问它的跟绘图和坐标有关的属性,如frame,bounds等,实际上内部都是访问它所在CALayer的相关属性
  • UIView有个layer属性,可以返回它的主CALayer实例,UIView有一个layerClass方法,返回主layer所使用的类,UIView的子类,可以通过重载这个方法,来让UIView使用不同的CALayer来显示,如:
- (class) layerClass { // 使某个UIView的子类使用GL来进行绘制 return ([CAEAGLLayer class]);}
  • UIView的CALayer类似UIView的子View树形结构,也可以向它的layer上添加子layer,来完成某些特殊的显示。例如下面的代码会在目标View上敷上一层黑色的透明薄膜。
grayCover = [[CALayer alloc]init];grayCover.backgroudColor = [[UIColor blackColor]colorWithAlphaComponent:0.2].CGColor;[self.layer addSubLayer:grayCover];
  • 补充部分,这部分有深度了,大致了解一下吧,UIView的layer树形在系统内部被系统维护着三份copy
    • 逻辑树,就是代码里可以操纵的,例如更改layer的属性等等就在这一份
    • 动画树,这是一个中间层,系统正是在这一层上更改属性,进行各种渲染操作
    • 显示树,这棵树的内容是当前正被显示在屏幕上的内容
    • 这三棵树的逻辑结构都是一样的,区别只有各自的属性