日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

iOS之使用CAShapeLayer实现复杂的View遮罩效果

發布時間:2024/5/17 编程问答 55 豆豆
生活随笔 收集整理的這篇文章主要介紹了 iOS之使用CAShapeLayer实现复杂的View遮罩效果 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

一、案例演示

最近在整理一個聊天的項目的時候,發送圖片的時候,會有一個三角的指向效果,指向這張圖片的發送者。服務端返回給我們的圖片只是一張矩形的圖片,如何把一張矩形的圖片或者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;

總結

以上是生活随笔為你收集整理的iOS之使用CAShapeLayer实现复杂的View遮罩效果的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。