zoukankan      html  css  js  c++  java
  • IOS开发UI篇--使用CAShapeLayer实现复杂的View的遮罩效果

    一、案例演示

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

    1

    二、实现机制

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

    2

    三、实现代码

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

     1 @implementation CAShapeLayer (ViewMask)
     2 
     3 + (instancetype)createMaskLayerWithView : (UIView *)view{
     4 
     5     CGFloat viewWidth = CGRectGetWidth(view.frame);
     6     CGFloat viewHeight = CGRectGetHeight(view.frame);
     7 
     8     CGFloat rightSpace = 10.;
     9     CGFloat topSpace = 15.;
    10 
    11     CGPoint point1 = CGPointMake(0, 0);
    12     CGPoint point2 = CGPointMake(viewWidth-rightSpace, 0);
    13     CGPoint point3 = CGPointMake(viewWidth-rightSpace, topSpace);
    14     CGPoint point4 = CGPointMake(viewWidth, topSpace);
    15     CGPoint point5 = CGPointMake(viewWidth-rightSpace, topSpace+10.);
    16     CGPoint point6 = CGPointMake(viewWidth-rightSpace, viewHeight);
    17     CGPoint point7 = CGPointMake(0, viewHeight);
    18 
    19 
    20     UIBezierPath *path = [UIBezierPath bezierPath];
    21     [path moveToPoint:point1];
    22     [path addLineToPoint:point2];
    23     [path addLineToPoint:point3];
    24     [path addLineToPoint:point4];
    25     [path addLineToPoint:point5];
    26     [path addLineToPoint:point6];
    27     [path addLineToPoint:point7];
    28     [path closePath];
    29 
    30     CAShapeLayer *layer = [CAShapeLayer layer];
    31     layer.path = path.CGPath;
    32 
    33     return layer;
    34 }
    35 
    36 @end
    View Code

    四、调用方式

    1 UIView *view = [[UIView alloc] initWithFrame:CGRectMake(40, 50, 80, 100)];
    2 view.backgroundColor = [UIColor orangeColor];
    3 [self.view addSubview:view];
    4 
    5 CAShapeLayer *layer = [CAShapeLayer createMaskLayerWithView:view];
    6 view.layer.mask = layer;
    View Code

    五、联系方式

    博客:http://blog.csdn.net/yixiangboy
    github:https://github.com/yixiangboy

  • 相关阅读:
    本地邮件系统的安装及配置
    通用性站点管理后台(Bee OPOA Platform) (2) 快速开发特性
    (转).NET Framework 自动内存管理机制深入剖析 (C#分析篇)
    通用性站点管理后台(Bee OPOA Platform) (3) MVC特性
    通用性站点管理后台(Bee OPOA Platform) (4) DAL
    通用性站点管理后台(Bee OPOA Platform) (1)
    【讨论】一个接口的世界
    Ubuntu Mono 初体验
    发现assembly的dll在temp里,AppDomain无法动态加载那个assembly
    熟知android模拟器的快捷键
  • 原文地址:https://www.cnblogs.com/fengmin/p/5318626.html
Copyright © 2011-2022 走看看