IOS如何使用CAShapeLayer實現(xiàn)復雜的View的遮罩效果
一、案例演示
最近在整理一個聊天的項目的時候,發(fā)送圖片的時候,會有一個三角的指向效果,指向這張圖片的發(fā)送者。服務端返回給我們的圖片只是一張矩形的圖片,我們?nèi)绾伟岩粡埦匦蔚膱D片或者View,加上一層自定義遮罩效果,就是本文要講的內(nèi)容。效果演示如下:第一張是一個View的遮罩效果,第二張是UIImageView的遮罩效果。
二、實現(xiàn)機制
在每一View的layer層中有一個mask屬性,他就是專門來設置該View的遮罩效果的。該mask本身也是一個layer層。我們只需要生成一個自定義的layer,然后覆蓋在需要遮罩的View上面即可。問題就歸于如何生成入上圖所示的不規(guī)則圖片的Layer。CAShapeLayer可以根據(jù)幾個點的依次連線,產(chǎn)生一個閉合空間的layer。如下圖所示:
三、實現(xiàn)代碼
實現(xiàn)方式為實現(xiàn)了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
四、調(diào)用方式
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;
作者:yixiangboy
地址:http://blog.csdn.net/yixiangboy/article/details/50485250
以上就是本文的全部內(nèi)容,希望對大家學習IOS程序設計有所幫助。
相關文章
iOS開發(fā)教程之識別圖片中二維碼功能的實現(xiàn)
長按識別二維碼這個功能相信對大家來說都不陌生,最近工作中就遇到了這個需求,所以下面這篇文章主要給大家介紹了關于利用iOS識別圖片中二維碼的相關資料,文中通過示例代碼介紹的非常詳細,需要的朋友可以參考下2018-07-07