博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
使用CAShapeLayer实现复杂的View的遮罩效果
阅读量:6423 次
发布时间:2019-06-23

本文共 1744 字,大约阅读时间需要 5 分钟。

一、案例演示

最近在整理一个聊天的项目的时候,发送图片的时候,会有一个三角的指向效果,指向这张图片的发送者。服务端返回给我们的图片只是一张矩形的图片,我们如何把一张矩形的图片或者View,加上一层自定义遮罩效果,就是本文要讲的内容。效果演示如下:第一张是一个View的遮罩效果,第二张是UIImageView的遮罩效果。 

演示图片

二、实现机制

在每一View的layer层中有一个mask属性,他就是专门来设置该View的遮罩效果的。该mask本身也是一个layer层。我们只需要生成一个自定义的layer,然后覆盖在需要遮罩的View上面即可。问题就归于如何生成入上图所示的不规则图片的Layer。CAShapeLayer可以根据几个点的依次连线,产生一个闭合空间的layer。如下图所示: 

这里写图片描述

三、实现代码

实现方式为实现了CAShapeLayer的ViewMask的Category。

@implementation CAShapeLayer (ViewMask)+ (instancetype)createMaskLayerWithView : (UIView *)view{    CGFloat viewWidth = CGRectGetWidth(view.frame);    CGFloat viewHeight = CGRectGetHeight(view.frame);    CGFloat rightSpace = 10.;    CGFloat topSpace = 15.;    CGPoint point1 = CGPointMake(0, 0);    CGPoint point2 = CGPointMake(viewWidth-rightSpace, 0);    CGPoint point3 = CGPointMake(viewWidth-rightSpace, topSpace);    CGPoint point4 = CGPointMake(viewWidth, topSpace);    CGPoint point5 = CGPointMake(viewWidth-rightSpace, topSpace+10.);    CGPoint point6 = CGPointMake(viewWidth-rightSpace, viewHeight);    CGPoint point7 = CGPointMake(0, viewHeight);    UIBezierPath *path = [UIBezierPath bezierPath];    [path moveToPoint:point1];    [path addLineToPoint:point2];    [path addLineToPoint:point3];    [path addLineToPoint:point4];    [path addLineToPoint:point5];    [path addLineToPoint:point6];    [path addLineToPoint:point7];    [path closePath];    CAShapeLayer *layer = [CAShapeLayer layer];    layer.path = path.CGPath;    return layer;}@end

四、调用方式

UIView *view = [[UIView alloc] initWithFrame:CGRectMake(40, 50, 80, 100)];view.backgroundColor = [UIColor orangeColor];[self.view addSubview:view]; CAShapeLayer *layer = [CAShapeLayer createMaskLayerWithView:view]; view.layer.mask = layer;

 

转载于:https://www.cnblogs.com/yulang314/p/5121820.html

你可能感兴趣的文章
openshift 使用curl命令访问apiserver
查看>>
JAVA编程技巧之如何实现HTTP的断点续传(原理篇)
查看>>
MyEclipse中点击Deploy MyEclipse J2EE Project to Server无响应解决方法
查看>>
SharePoint Server 2013 让上传文件更精彩
查看>>
分布式链路追踪系统预研第二篇
查看>>
模拟MySQL命令
查看>>
关于MySQL字符集问题:Specified key was too long; max key length is 767 bytes
查看>>
Python初学基础
查看>>
看板管理大型项目-6.跟踪总体目标
查看>>
CentOS6.4下Mysql数据库的安装与配置
查看>>
tarjan
查看>>
redis命令
查看>>
【原创】PostgreSQL 对简单树的遍历
查看>>
采用python的pyquery引擎做网页爬虫,进行数据分析
查看>>
《H3C交换机配置与管理完全手册》(第二版)前言和目录
查看>>
Skype for Business Server 2015-03-后端服务器-3-验证
查看>>
初学者如何学习运维?
查看>>
XAML实例教程系列 - 依赖属性和附加属性
查看>>
动软社会化分享社区系统V1.3版发布
查看>>
祝贺洪春《构建高可用Linux服务器》第二版发行!
查看>>