相信很多人在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形状的效果。
通过一个例子来简单说明下:
通过上面的代码就能简单的封装一个圆形图片展示的效果
调用也非常简单,一句话搞定:
效果是这样的:
下面进入主题,用layer实现蒙板效果,先看效果:
直接上代码了:
viewDidload中的代码如下:
我简单的分析一下蒙板的原理:我们都知道控件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。