前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >UI篇-Layer几个关键点补充

UI篇-Layer几个关键点补充

作者头像
進无尽
发布2018-09-12 18:35:04
8940
发布2018-09-12 18:35:04
举报
文章被收录于专栏:進无尽的文章
前言

强大的UIView是基于 CALayer实现的,它的重要性不言而喻,相信大家也都有自己的研究和理解,今天这片文章里的内容是几个关键点的补充。

CALayer 和 UIView的关系

CALayer是Core Animation的基础,UIKit 相关内容实现的基础 简单来说,View和Layer最大的区别就是View可以接受用户输入(例如触摸)而Layer不可以,Layer单独并不能呈现出任何可视的内容,必须依托于View。Layer只是几何上呈现给用户的东西,它较为轻量,通常采用Cache技术,对资源消耗也较小。

CALayer是什么?

摘自官网的一句话-Layers Provide the Basis for Drawing and Animations(Layers是绘图和动画的基础) Layer是在3D空间中的2D平面。Layer管理的几何(例如rotate,transfrom),内容(image等),和可视属性(backgroundColor,alpha)等信息。Layer主要通过管理bitmap来维护自己的状态信息,从这一点上来说,Layer可以看作对象模型,因为他们主要用来管理数据。

Layer是基于bitmap的,它会捕获View要呈现的内容,然后cache在一个bitmap中,这个bitmap可以看作一个对象。这样每次进行操作,例如平移旋转等,只是bitmap的矩阵运算。基于Layer的动画过程如图

由于基于Layer的绘制是处理静态的Bitmap的,而bitmap的处理又是GPU所擅长的,所以它的效率要比基于View绘制的高很多,因为基于View绘制的每次都要进行drawRect的调用重新绘制。

** Layer支持继承,支持添加Sublayer,支持对sublayer进行层次调整**

常用的Layer子类

代码语言:javascript
复制
CAEmitterLayer  发射器层,用来控制粒子效果

CAGradientLayer  梯度层,颜色渐变

CAEAGLayer  用OpenGL ES绘制的层

CAReplicationLayer  用来自动复制sublayer

CAScrollLayer  用来管理可滑动的区域

CAShapeLayer   绘制立体的贝塞尔曲线

CATextLayer  可以绘制AttributeString

CATiledLayer用来管理一副可以被分割的大图

CATransformLayer    用来渲染3D layer的层次结构

管理Layer内容的几个函数

代码语言:javascript
复制
addSublayer:
insertSublayer:above:
insertSublayer:atIndex:
insertSublayer:below:
removeFromSuperlayer
replaceSublayer:with:
** anchorPoint和position**

和UIView不同,Layer主要由三个属性来设置位置(极少用Frame):

代码语言:javascript
复制
bounds -  设置大小
anchorPoint -设置锚点(锚点对后续的layer动画有很大影响,默认(0.5,0.5))
position -  锚点在superLayer中的位置
contentGravity这个属性。这个属性决定了contents如何填充。

具体分为两个方面, 方面一,位置方面具体如图

方面二,比例变换方面如图

一些实例效果

彩色环状进度条

粒子动画

CATransform3D 是不是明显发现蓝色的3D层效果更强烈一些

CAReplicatorLayer.gif

CAReplicatorLayer.gif

上图效果具体实现参考另一位作者文章

(未完待续......)

本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2016.10.25 ,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 前言
  • CALayer 和 UIView的关系
  • CALayer是什么?
  • ** Layer支持继承,支持添加Sublayer,支持对sublayer进行层次调整**
  • ** anchorPoint和position**
  • contentGravity这个属性。这个属性决定了contents如何填充。
  • 一些实例效果
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档