iOS之CALayer

CALayer

  • 在iOS中,UIView之所以能显示在屏幕上,完全是因为它内部有一个图层
  • 在创建UIView对象时,UIView内部会自动创建一个图层(即CALayer对象),通过UIView的layer属性可以访问这个层
  • 当UIView需要显示到屏幕上时,会调用drawRect:方法进行绘制,并且会将所有内容绘制在自己的图层上,绘图完毕后,系统会将图层拷贝到屏幕上,于是就完成了UIView的显示
  • 也就是说:UIView本身不具备显示的功能,是它内部的层才有显示功能
    // 设置阴影
    // Opacity:不透明度
    _redView.layer.shadowOpacity = 1;
    // 阴影偏移
    _redView.layer.shadowOffset = CGSizeMake(10, 10);
    // 阴影颜色
    _redView.layer.shadowColor = [UIColor yellowColor].CGColor;
    // 阴影模糊半径
    _redView.layer.shadowRadius = 50;

    // 圆角半径
    _redView.layer.cornerRadius = 50;
    //是否将超出根层范围的裁切掉
    _redView.layer.masksToBounds = YES;
    // 边框
    _redView.layer.borderWidth = 1;
    // 边框颜色
    _redView.layer.borderColor = [UIColor whiteColor].CGColor;
    //通过transform属性可以设置图层的形变
    _redView.layer.transform
  • 图层也是可以新建的
    // 创建图层
    CALayer *layer = [CALayer layer];
    layer.frame = CGRectMake(50, 50, 200, 200);
    //背景颜色
    layer.backgroundColor = [UIColor redColor].CGColor;
    // 设置图层内容
    layer.contents = (id)[UIImage imageNamed:@"icon"].CGImage;

    // 设置锚点(决定了position是哪一点)
    layer.anchorPoint = CGPointMake(0.5, 1);
    // 设置在父图层中的位置
    layer.position = CGPointMake(100 , 100);
    [self.view.layer addSublayer:layer];

  • 图层的很多属性是有隐式动画,就是说改变图层的这些属性,就会自动的有动画效果,这些属性有一个统一的标志,在注释中有Animatable标注的
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • 在iOS中随处都可以看到绚丽的动画效果,实现这些动画的过程并不复杂,今天将带大家一窥ios动画全貌。在这里你可以看...
    每天刷两次牙阅读 8,551评论 6 30
  • 在iOS中随处都可以看到绚丽的动画效果,实现这些动画的过程并不复杂,今天将带大家一窥iOS动画全貌。在这里你可以看...
    F麦子阅读 5,141评论 5 13
  • 前言 本文只要描述了iOS中的Core Animation(核心动画:隐式动画、显示动画)、贝塞尔曲线、UIVie...
    GitHubPorter阅读 3,651评论 7 11
  • Core Animation其实是一个令人误解的命名。你可能认为它只是用来做动画的,但实际上它是从一个叫做Laye...
    小猫仔阅读 3,775评论 1 4
  • 暖睡榻中夜难眠,腹饥辗转懒推轩。 探窗风疾狼猿吼,长街赖冷星点烟。 抬眼霜月挂高阁,俯耳醉汉骂路边。 扎鞋瓮衣出门...
    长安旧人阅读 1,424评论 32 48