文章目录
  1. 1. 锚点
  2. 2. 坐标系
    1. 2.1. 翻转几何结构
    2. 2.2. Z坐标轴

UIView有三个比较重要的布局属性:frameboundscenter,对应到CALayer叫做frameboundsposition

  • frame代表图层的外部坐标,也就是父图层上占据的空间
  • bounds内部坐标,{0,0}是图层的左上角
  • centerposition都代表了相对父图层的anchorPoint所在的位置

锚点

默认的anchorPoint位于图层的中点,所以图层将会以这个点为中心放置,anchorPoint属性并没有暴露个UIView接口暴露出来,这也就是视图position属性被叫做center,但是图层的anchorPoint可以被移动

anchorPoint用单位坐标来描述,图层左上角是{0,0},右下角是{1,1},默认坐标是{0.5,0.5},anchorPoint也可以通过指定x和y值小于或大于1,使它放置在图层范围之外。

坐标系

一个图层的position依赖于它父图层的bounds,如果父图层发生了移动,它的所有子图层也会跟着移动
定义一个图层坐标系下的点或者矩形转换成另一个图层坐标系下的点或者矩形

  • convertPoint(p: CGPoint, toLayer:CALayer)
  • convertPoint(p: CGPoint,toLayer:CALayer)
  • convertRect(rect: CGRect,fromLayer: CALayer)
  • convertRect(rect: CGRect,toLayer: CALayer)

翻转几何结构

通常iOS一个图层的position位于父图层的左上角,Mac OS则位于左下角,Core Animation可以通过geometryFlipped属性来适配这两种情况,它决定了一个图层的坐标系是否相对父图层垂直翻转。

Z坐标轴

CALayer存在一个三维空间,除了posistionanchorPoint属性外,CALayer还有另外两个属性,zPositionanchorPointZ两者都是在Z轴上描述图层位置的浮点类型。
zPosition决定图层显示顺序,图层根据子图层的sublayers出现的顺序来类绘制。

1
self.greenView.layer.zPosition = 1.0f

文章目录
  1. 1. 锚点
  2. 2. 坐标系
    1. 2.1. 翻转几何结构
    2. 2.2. Z坐标轴