一、案例演示

最近在整理一个聊天的项目的时候,发送图片的时候,会有一个三角的指向效果,指向这张图片的发送者。服务端返回给我们的图片只是一张矩形的图片,我们如何把一张矩形的图片或者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 = .;
CGFloat topSpace = .; CGPoint point1 = CGPointMake(, );
CGPoint point2 = CGPointMake(viewWidth-rightSpace, );
CGPoint point3 = CGPointMake(viewWidth-rightSpace, topSpace);
CGPoint point4 = CGPointMake(viewWidth, topSpace);
CGPoint point5 = CGPointMake(viewWidth-rightSpace, topSpace+.);
CGPoint point6 = CGPointMake(viewWidth-rightSpace, viewHeight);
CGPoint point7 = CGPointMake(, 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(, , , )];
view.backgroundColor = [UIColor orangeColor];
[self.view addSubview:view]; CAShapeLayer *layer = [CAShapeLayer createMaskLayerWithView:view];
view.layer.mask = layer;

最新文章

  1. C# 通过反射类动态调用DLL方法
  2. cmake 编译 c++ dll 的一个例子
  3. [CareerCup] 11.5 Search Array with Empty Strings 搜索含有空字符串的数组
  4. qmake理解(还可以加入Lex Yacc文件)
  5. html之a标签
  6. Java面试之SE基础基本数据类型
  7. Vim的可视模式
  8. HDU_1426——数独问题,DFS
  9. react基于webpack和babel以及es6的项目搭建
  10. 搜索(BFS)
  11. SQL数据库语句练习题目
  12. Linkin大话Java和internet概念
  13. Your Database is downloaded and backed up on....(腾讯云的mysql被攻击)
  14. 计算机编码--c语言中输出float的十六进制和二进制编码
  15. webpack学习笔记-2-file-loader 和 url-loader
  16. numpy.random.uniform()
  17. VB.NET工作记录
  18. Netty入门(八)构建Netty HTTP/HTTPS应用
  19. Unity----Scene加载问题
  20. 关于str.split(",")中间 什么时候该加\\转义

热门文章

  1. git配置命令
  2. tableview中用动画效果改变cell的高度
  3. NOIp知识集合 By cellur925
  4. MyBatis入门学习笔记(一)
  5. Nacos深入浅出(六)
  6. HDU6442(二项式)
  7. Net Core 分布式微服务框架
  8. openstack安装newton版本neutron服务部署(四)
  9. 传纸条(scrip)
  10. springboot项目实现批量新增功能