美文网首页iOS开发技术
CALayer mask属性实现蒙板效果

CALayer mask属性实现蒙板效果

作者: 小饼干是只松鼠 | 来源:发表于2018-02-22 10:38 被阅读10次

相信很多人在ios上实现控件圆角的时候都用过:cornerRadius这个属性,例如实现圆形头像,一般我会这么写:

self.headImageView.layer.masksToBounds = YES;
self.headImageView.layer.cornerRadius = 20;

这样就能简单的实现图片圆角效果了,那么,实现圆角效果的原理是什么呢?下面我简单的谈一下我自己的理解(错误指出还请指出)。

相信我们都注意到了,这里使用了一个layer属性,layer其实是控件上的一个层。而我们平时用的控件组成部分其实是 UIView + layer,这两部分实现了控件的展示。而layer的大小和形状是直接影响我们视觉中所看的样子,而并非控件中的UIView层。通过改变layer的形状和大小,能改变控件所呈现的样子。那么是如何改变layer的形状呢?这里就要涉及到layer的一个属性mask,下面给出苹果官方的定义:

/* A layer whose alpha channel is used as a mask to select between the

  • layer's background and the result of compositing the layer's
  • contents with its filtered background. Defaults to nil. When used as
  • a mask the layer's compositingFilter' andbackgroundFilters'
  • properties are ignored. When setting the mask to a new layer, the
  • new layer must have a nil superlayer, otherwise the behavior is
  • undefined. Nested masks (mask layers with their own masks) are
  • unsupported. */

大概意思是:mask是一个layer层,并且作为背景层和组成层之间的一个遮罩层通道,默认是nil。并且如果要创建新的layer赋给mask,那么新的layer必须没有superlayer,也不支持含有子mask。

我简单的理解为mask是个介于背景层和表现层之间的一个遮罩层,如果要创建新的layer赋给这个遮罩层,则这个新layer不能有superlayer,也不能再上面添加子mask

通过,上面的解释可以看到,layer的大小和形状是受到mask遮罩层的影响的,可以通过赋给mask层一个新layer,来实现改变layer形状的效果。

通过一个例子来简单说明下:

image

通过上面的代码就能简单的封装一个圆形图片展示的效果

调用也非常简单,一句话搞定:

image

效果是这样的:

image

下面进入主题,用layer实现蒙板效果,先看效果:

image

直接上代码了:

image

viewDidload中的代码如下:

image

我简单的分析一下蒙板的原理:我们都知道控件view有一个alpha属性用来设置透明度,默认alpha=1,只有当alpha不为0是我们才能正常的看到View的样子,alpha其实改变的是mask和background layer的透明度,来实现透明效果。而mask是控件view上的一层layer,mask也有一个alpha,要想看到view,只有当mask的透明度不为0时,我们才能看到mask后面的view的样子,view自带的masklayer是不透明的。新创建的masklayer的是透明的,因此,我们只需要给新创建的masklayer一个颜色,使他不透明就能看见蒙板后的View了,而蒙板外是透明的,这样就能实现蒙板效果了。原理大概是这样了。

版权声明:本文为vlions博主原创文章,您可自由转载,但请保留博主信息和文章链接URL http://blog.csdn.net/qq_22600319/article/details/52189746

相关文章

  • CALayer mask属性实现蒙板效果

    相信很多人在ios上实现控件圆角的时候都用过:cornerRadius这个属性,例如实现圆形头像,一般我会这么写:...

  • CALayer的mask属性

    CALayer的mask属性俗称蒙版。@property(nullable, strong) CALayer *m...

  • 图层蒙版的理解

    图层蒙版的理解 CALayer有一个属性叫做mask可以解决这个问题。这个属性本身就是个CALayer类型,有和其...

  • iOS使用蒙版构建进度条

    蒙版 @property(nullable, strong) CALayer *mask; A layer who...

  • web前端中的遮罩蒙版

    在前端开发中,有一些效果需要实现遮罩蒙版的效果,有几种方案,记录一下 CSS实现 css 中mask属性,最早是出...

  • iOS 巧用Mask属性之绘制渐变进度条 & 镂空效果

    先来了解下Mask属性到底是什么? Mask 英文解释是蒙板/面罩,平时我们称为蒙层. 在苹果官方文档里如下图,意...

  • CALayer属性mask

    CALayer的属性mask,mask也是一个layer,这边称它为maskLayer。介绍中描述 An opti...

  • CALayer之mask使用

    mask是CALayer的一个属性,它本身也是一个CALayer类。mask有和其他图层一样的绘制和布局属性。它类...

  • 自定义转场动画-小圆点扩散

    mask的理解 CALayer有一个属性叫做mask。比如imageLayer有一个maskLayer作为mask...

  • CAlayer

    //CALayer 蒙版图层真正厉害的地方在于蒙版图层不局限于静态图。任何有图层构成的都可以作为mask属性,这意...

网友评论

    本文标题:CALayer mask属性实现蒙板效果

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