1 UIView与 CALayer是平行的,图层概念
2 CALayer可以直接显示图片,给CALayer的属性contents赋值,其类行为:CGImage,如果用UIIMage需要这样写:layer.contents = (__bridge id)UIImage.CGImage
3 如果显示出来的图片变形可以设置layer.contentsGravity,如果这样设置self.layerView.layer.contentsGravity =kCAGravityResizeAspect;相当于UIImageView的contentMode设置为UIViewContentModeScaleAspectFit,它还能在图层中等比例拉伸以适应图层的边界
4 要想使图片在retail屏上正确的显示,需要设定CAlayer的contentScale属性,使得图片在不同分辨率的设备上正确的显示,通常这样做:layer.contentsScale = [UIScreen mainScreen].scale;
5 maskToBounds,如果图片超出了视图的边界,需要设定maskToBounds= YES,只显示视图范围内的图片,这个与UIView的clipsToBounds作用一样
6 contentRect,允许在图层边框里显示寄宿图的一个子区域 ,采用单位坐标,默认值是:(0,0,1,1),意味着整个寄宿图都可见,其应用为图像拼合,如果改为(0,0,0.5,0.5),如下所示:
7 contentsCenter,是一个CGRect,定义了固定的边框和在图层上可拉伸的区域,改变contentsCenter的值并不会影响到寄宿图的显示,除非这个图层的大小改变了,才能看到效果,其默认值为{0,0,1,1},这意味着如果大小改变了(由conttensGravity决定),那么寄宿图将会均匀的拉开,contentsCenter设置为{0.25, 0.25, 0.5, 0.5}的效果
这意味着如果重设尺寸,边框仍然是连续的,他与UIImage里的-resizableImageWithCapInsets: 方法效果非常类似
8 自定义绘制寄宿图,用Core graphics或继承子自UIView并实现-drawRect:方法
对UIView来说,drawRect:方法并不是必须的,UIView检测到实现了drawRect方法,才会为视图分配一个寄宿图,这个寄宿图的像素大小等于视图大小乘以contentsScale。
另外CALayer有一个delegate,当CALayer需要一个内容特定的信息时,就会请求实现这个协议的代理方法,当需要被重绘时,会调用:(void)displayLayer:(CALayerCALayer *)layer;,如果代理没实现该方法,- (void)drawLayer:(CALayer *)layer inContext:(CGContextRef)ctx;
在调用这个方法之前,CALayer创建了一个合适尺寸的空寄宿图(尺寸由bounds和contentsScale决定)和一个Core Graphics的绘制上下文环境,为绘制寄宿图做准备,他作为ctx参数传入。
当图层显示在屏幕上时,并不会重绘他的图层,需要显示的调用display方法
@implementationViewController- (void)viewDidLoad{ [superviewDidLoad]; //create sublayerCALayer *blueLayer = [CALayerlayer]; blueLayer.frame=CGRectMake(50.0f,50.0f,100.0f,100.0f); blueLayer.backgroundColor= [UIColorblueColor].CGColor;//set controller as layer delegateblueLayer.delegate= self;//ensure that layer backing image uses correct scaleblueLayer.contentsScale= [UIScreenmainScreen].scale;//add layer to our view[self.layerView.layeraddSublayer:blueLayer];//force layer to redraw[blueLayerdisplay];}- (void)drawLayer:(CALayer *)layerinContext:(CGContextRef)ctx{//draw a thick red circleCGContextSetLineWidth(ctx,10.0f);CGContextSetStrokeColorWithColor(ctx, [UIColorredColor].CGColor);CGContextStrokeEllipseInRect(ctx, layer.bounds);}
9 UIView的bounds,frame,center对应CALayer的bounds,frame和position,其中frame是由bounds和position以及transform计算出来的
图层的anchorpoint通过position来控制他的frame的位置,anchorpoint是移动图层的把柄
anchorPoint默认位于图层的中心位置,图层会以这个点为中心放置,图层的anchorPoint是可以被移动的