CALayer mask属性实现蒙板效果

相信很多人在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' and `backgroundFilters'
* 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形状的效果。

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


CALayer mask属性实现蒙板效果_第1张图片


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

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



效果是这样的:


CALayer mask属性实现蒙板效果_第2张图片



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



直接上代码了:


CALayer mask属性实现蒙板效果_第3张图片


viewDidload中的代码如下:


CALayer mask属性实现蒙板效果_第4张图片


我简单的分析一下蒙板的原理:我们都知道控件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了,而蒙板外是透明的,这样就能实现蒙板效果了。原理大概是这样了。

你可能感兴趣的:(iOS开发学习)