美文网首页糖糖的iOS专题
如何自定义CALayer

如何自定义CALayer

作者: 我的梦想之路 | 来源:发表于2016-07-27 22:12 被阅读38次

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;

圆角半径

@property CGColorRef borderColor;

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

@property(retain) id contents;

自定义CALayer的方式创建UIView的方式非常相似.
     CALayer *layer = [CALayer layer];
     layer.frame = CGRectMake(50, 50, 100, 100);
     layer.backgroundColor = [UIColor redColor].CGColor;
     [self.view.layer addSublayer:layer];

    给layer设置图片.
    layer.contents = (id)[UIImage imageNamed:@"阿狸头像"].CGImage;

为什么要使用CGImageRef、CGColorRef?

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

UIColor、UIImage是定义在UIKit框架中的

其次

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

但是UIKit只能在iOS中使用

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

UIView和CALayer都能够显示东西,该怎样选择?

   对比CALayer,UIView多了一个事件处理的功能。
   也就是说,CALayer不能处理用户的触摸事件,而UIView可以
   如果显示出来的东西需要跟用户进行交互的话,用UIView;
   如果不需要跟用户进行交互,用UIView或者CALayer都可以
  CALayer的性能会高一些,因为它少了事件处理的功能,更加轻量级
- (void)viewDidLoad {
    [super viewDidLoad];

    
    CALayer *layer = [CALayer layer];
    layer.backgroundColor = [UIColor redColor].CGColor;
    layer.frame = CGRectMake(50, 50, 100, 100);
    
    [self.view.layer addSublayer:layer];
    
    layer.contents = (id)[UIImage imageNamed:@"阿狸头像"].CGImage;
  
}
阿狸头像

相关文章

  • 6.2 CALayer 的简单使用、自定义CALayer、代理绘

    一:CALayer 的简单使用 11.png 二:自定义CALayer 自定义CALayer.png 代理绘制图层...

  • 03-自定义Layer.

    Make by:弓_虽_子 1.如何自定义Layer. 自定义CALayer的方式创建UIView的方式非常相似....

  • CALayer 简介

    CALayer1-简介CALayer2-创建新的层 CALayer3-层的属性 CALayer4-自定义层 CAL...

  • CALyer介绍

    CALayer1-简介CALayer2-创建新的层CALayer3-层的属性CALayer4-自定义层 注意点 第...

  • 如何自定义CALayer

    CALayer的属性 宽度和高度 @property CGRect bounds; 位置(默认指中点,具体由anc...

  • 核心动画01

    01-CALayer的基本操作. 02-自定义CALayer 03-position和anchorPoint 04...

  • CALayer

    对于使用CALayer自定义控件的实现,一些外观方面的属性定义可以直接修改对应CALayer的属性,比如颜色。其次...

  • Core Animation核心动画

    CALayer层(显示的基础)UIView核心显示功能就是依靠CALayer实现的如何获取一个CALayer对象1...

  • 顶部加载的progressive的初步

    加载条粗细可以自定义 CALayer的两个重要的subClass:CAGradientLayer和CAShapeL...

  • 《iOS核心动画高级技巧》笔记 — Part1

    中文译文地址 一、UIView与CALayer UIView实现绘制自定义任务时,调用-drawRect:方法,为...

网友评论

    本文标题:如何自定义CALayer

    本文链接:https://www.haomeiwen.com/subject/kizojttx.html