zoukankan      html  css  js  c++  java
  • iOS-CALayer的介绍

    一 、CALayer介绍

    • 在iOS中,你能看得见摸得着的东西基本上都是UIView,比如一个按钮、一个文本标签、一个文本输入框、一个图标等等,这些都是UIView
    •  其实UIView之所以能显示在屏幕上,完全是因为它内部的一个图层
    • 在创建UIView对象时,UIView内部会自动创建一个图层(即CALayer对象),通过UIView的layer属性可以访问这个层

      @property (nonatomic,readonly,retain) CALayer *layer; 

    •  当UIView需要显示到屏幕上时,会调用drawRect:方法进行绘图,并且会将所有内容绘制在自己的图层上,绘图完毕后,系统会将图层拷贝到屏幕上,于是就完成了UIView的显示
    • 换句话说,UIView本身不具备显示的功能,是它内部的层才有显示功能

    二、CALayer的基本使用

    • 通过操作CALayer对象,可以很方便地调整UIView的一些外观属性
    • 还可以给图层添加动画,来实现一些比较炫酷的效果

    三、CALayer的属性

    • 宽度和高度

      @property CGRect bounds;

    • 位置(默认指中点,具体由anchorPoint决定)

      @property CGPoint position;

    •  锚点(x,y的范围都是0-1),决定了position的含义

      @property CGPoint anchorPoint;

    •  背景颜色(CGColorRef类型)

      @property CGColorRef backgroundColor;

    •  形变属性

      @property CATransform3D transform;

    • 边框颜色(CGColorRef类型)

      @property CGColorRef borderColor;

    •  边框宽度

      @property CGFloat borderWidth;

    • 内容(比如设置为图片CGImageRef)

      @property(retain) id contents;

      在此介绍CALayer有2个非常重要的属性:position和anchorPoint

      @property CGPoint position;

      用来设置CALayer在父层中的位置,以父层的左上角为原点(0, 0)

      @property CGPoint anchorPoint;

      称为“定位点”、“锚点”

      决定着CALayer身上的哪个点会在position属性所指的位置

      以自己的左上角为原点(0, 0)

      它的x、y取值范围都是0~1,默认值为(0.5, 0.5)

     四、关于CALayer的疑惑

      首先

    • CALayer是定义在QuartzCore框架中的
    • CGImageRef、CGColorRef两种数据类型是定义在CoreGraphics框架中的
    • UIColor、UIImage是定义在UIKit框架中的

       其次

    • QuartzCore框架和CoreGraphics框架是可以跨平台使用的,在iOS和Mac OS X上都能使用
    • 但是UIKit只能在iOS中使用

       为了保证可移植性,QuartzCore不能使用UIImage、UIColor,只能使用CGImageRef、CGColorRef

  • 相关阅读:
    源码剖析Django REST framework的请求生命周期
    Django REST framework中的版本控制
    Django REST framework反向生成url
    Django的ModelForm
    SQL Server 2008 R2导出数据脚本的方法
    未在本地计算机上注册 Microsoft.Jet.OLEDB.4.0 提供程序
    Webservice发布出现 测试窗体只能用于来自本地计算机的请求
    StreamWriter和StremReader简单的用法
    (转)PHP下编码转换函数mb_convert_encoding与iconv的使用说明
    (转)PHP中构造函数和析构函数解析
  • 原文地址:https://www.cnblogs.com/caofutao/p/4842796.html
Copyright © 2011-2022 走看看