002-Custom Drawing

1、Custom Drawing

  • 1、给contents赋CGImage的值不是唯一的设置图层图片的方法,也可以直接用Core Graphics直接绘制图层图片。能够通过继承UIView并实现 - drawRect: 方法来自定义绘制。

  • 2、CALayer有一个可选的delegate属性,实现了CALayerDelegate协议,当CALayer需要一个内容特定的信息时,就会从协议中请求。CALayerDelegate是一个非正式协议,其实就是说没有CALayerDelegate @protocol可以让你在类里面引用,你只需要调用你想调用的方法,CALayer会帮你做剩下的。

  • 3、当需要被重绘时,CALayer会请求它的代理给他一个寄宿图来显示。它通过调用下面这个方法做到的:- (void)displayLayer:(CALayer *)layer;趁着这个机会,如果代理想直接设置contents属性的话,它就可以这么做,不然没有别的方法可以调用了。如果代理不实现 - displayLayer: 方法,CALayer就会转而尝试调用下面的这个方法:- (void)drawLayer:(CALayer *)layer inContent:(CGContextRef)ctx;在调用这个方法之前,CALayer创建了一个合适尺寸的空寄宿图(尺寸由bounds和contentsScale决定)和一个Core Graphics的绘制上下文环境,为绘制寄宿图做准备,它作为ctx参数传入

2、示例如下

#import "ViewController.h"
//#import 

@interface ViewController ()
/**
 *  layerView
 */
@property (nonatomic, strong) UIView *layerView;

/**
 *  blueLayer
 */
@property (nonatomic, strong) CALayer *blueLayer;
@end

@implementation ViewController

- (void)viewDidLoad {
    [super viewDidLoad];
    // 背景颜色
    self.view.backgroundColor = [UIColor darkGrayColor];
    // View
    self.layerView = [[UIView alloc] initWithFrame:CGRectMake(100, 100, 200, 200)];
    self.layerView.backgroundColor = [UIColor whiteColor];
    [self.view addSubview:self.layerView];
    //blueLayer
    self.blueLayer = [CALayer layer];
    self.blueLayer.frame = CGRectMake(50, 50, 100, 100);
    self.blueLayer.backgroundColor = [UIColor blueColor].CGColor;
    self.blueLayer.contentsScale = [UIScreen mainScreen].scale;
    self.blueLayer.delegate = self;
    [self.layerView.layer addSublayer:self.blueLayer];
    [self.blueLayer display];
}

- (void)drawLayer:(CALayer *)layer inContext:(nonnull CGContextRef)ctx {
    //设置宽度
    CGContextSetLineWidth(ctx, 5.0);
    //设置颜色
    CGContextSetStrokeColorWithColor(ctx, [UIColor redColor].CGColor);
    //设置rect
//    CGContextStrokeRect(ctx, layer.bounds);
    CGContextStrokeEllipseInRect(ctx, layer.bounds);
}

效果如下

3、小结

  • 1、尽管我们没有用maskToBounds属性,绘制的那个圆仍然沿边界被裁剪了。这是因为当你使用CALayerDelegate绘制寄宿图的时候,并没有对超出边界外的内容提供绘制支持
  • 2、当使用寄宿画视图的图层的时候,你也不必实现- displayLayer: 和- drawLayer:inContext: 方法来绘制你的寄宿图。通常做法是实现UIView的 - drawRect:方法,UIView就会帮你做完剩下的工作,包括在需要绘制的时候调用 - display方法

你可能感兴趣的:(002-Custom Drawing)