IOS如何使用CAShapeLayer實(shí)現(xiàn)復(fù)雜的View的遮罩效果
一、案例演示
最近在整理一個(gè)聊天的項(xiàng)目的時(shí)候,發(fā)送圖片的時(shí)候,會(huì)有一個(gè)三角的指向效果,指向這張圖片的發(fā)送者。服務(wù)端返回給我們的圖片只是一張矩形的圖片,我們?nèi)绾伟岩粡埦匦蔚膱D片或者View,加上一層自定義遮罩效果,就是本文要講的內(nèi)容。效果演示如下:第一張是一個(gè)View的遮罩效果,第二張是UIImageView的遮罩效果。
二、實(shí)現(xiàn)機(jī)制
在每一View的layer層中有一個(gè)mask屬性,他就是專門來(lái)設(shè)置該View的遮罩效果的。該mask本身也是一個(gè)layer層。我們只需要生成一個(gè)自定義的layer,然后覆蓋在需要遮罩的View上面即可。問(wèn)題就歸于如何生成入上圖所示的不規(guī)則圖片的Layer。CAShapeLayer可以根據(jù)幾個(gè)點(diǎn)的依次連線,產(chǎn)生一個(gè)閉合空間的layer。如下圖所示:
三、實(shí)現(xiàn)代碼
實(shí)現(xiàn)方式為實(shí)現(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
以上就是本文的全部?jī)?nèi)容,希望對(duì)大家學(xué)習(xí)IOS程序設(shè)計(jì)有所幫助。
- iOS開(kāi)發(fā)之路--仿網(wǎng)易抽屜效果
- iOS毛玻璃效果的實(shí)現(xiàn)及圖片模糊效果的三種方法
- IOS等待時(shí)動(dòng)畫(huà)效果的實(shí)現(xiàn)
- iOS開(kāi)發(fā)中的ViewController轉(zhuǎn)場(chǎng)切換效果實(shí)現(xiàn)簡(jiǎn)介
- iOS開(kāi)發(fā)之使用Storyboard預(yù)覽UI在不同屏幕上的運(yùn)行效果
- iOS開(kāi)發(fā)中視圖的下拉放大和上拉模糊的效果實(shí)現(xiàn)
- IOS實(shí)現(xiàn)圖片輪播無(wú)限循環(huán)效果
- iOS實(shí)現(xiàn)圖片輪播效果
- iOS實(shí)現(xiàn)簡(jiǎn)單的抽屜效果
- iOS實(shí)現(xiàn)選項(xiàng)卡效果的方法
相關(guān)文章
iOS獲取當(dāng)前app的設(shè)備名稱和版本號(hào)等內(nèi)容
本文主要介紹了iOS獲取當(dāng)前app的設(shè)備名稱和版本號(hào)等內(nèi)容的方法。具有很好的參考價(jià)值,下面跟著小編一起來(lái)看下吧2017-03-03iOS自定義日歷控件的簡(jiǎn)單實(shí)現(xiàn)過(guò)程
這篇文章主要為大家詳細(xì)介紹了iOS自定義日歷控件的簡(jiǎn)單實(shí)現(xiàn)過(guò)程,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2016-09-09iOS開(kāi)發(fā)教程之識(shí)別圖片中二維碼功能的實(shí)現(xiàn)
長(zhǎng)按識(shí)別二維碼這個(gè)功能相信對(duì)大家來(lái)說(shuō)都不陌生,最近工作中就遇到了這個(gè)需求,所以下面這篇文章主要給大家介紹了關(guān)于利用iOS識(shí)別圖片中二維碼的相關(guān)資料,文中通過(guò)示例代碼介紹的非常詳細(xì),需要的朋友可以參考下2018-07-07iOS開(kāi)發(fā)自定義頁(yè)腳和頁(yè)眉技巧詳解
這篇文章主要為大家介紹了iOS開(kāi)發(fā)自定義頁(yè)腳和頁(yè)眉的技巧示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2022-07-07Swift和Objective-C 混編注意事項(xiàng)
這篇文章主要介紹了Swift和Objective-C 混編注意事項(xiàng)的相關(guān)資料,需要的朋友可以參考下2016-10-10iOS實(shí)現(xiàn)手指點(diǎn)擊出現(xiàn)波紋的效果
最近在閑暇的時(shí)間做了一個(gè)反饋手指點(diǎn)擊屏幕的效果,用到了CAShapeLayer和基本的動(dòng)畫(huà)知識(shí),實(shí)現(xiàn)的效果很贊,這種效果使用在某些頁(yè)面上肯定會(huì)給用戶更有趣的體驗(yàn),特別是面向兒童的app中。文中給出了詳細(xì)的示例代碼,感興趣的朋友們下面來(lái)一起看看吧。2016-12-12