欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

IOS如何使用CAShapeLayer實現(xiàn)復雜的View的遮罩效果

 更新時間:2016年03月24日 15:53:18   作者:yixiangboy  
這篇文章主要為大家詳細介紹了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 端聲音問題綜合解決方案

    討論在線教室 iOS 端聲音問題綜合解決方案

    這篇文章主要介紹了在線教室 IOS 端聲音問題綜合解決方案,從背景介紹,到技術總結,再到行業(yè)現(xiàn)狀,都進行了細致的說明,建議同學們仔細看一下
    2021-04-04
  • iOS獲取當前app的設備名稱和版本號等內(nèi)容

    iOS獲取當前app的設備名稱和版本號等內(nèi)容

    本文主要介紹了iOS獲取當前app的設備名稱和版本號等內(nèi)容的方法。具有很好的參考價值,下面跟著小編一起來看下吧
    2017-03-03
  • iOS自定義日歷控件的簡單實現(xiàn)過程

    iOS自定義日歷控件的簡單實現(xiàn)過程

    這篇文章主要為大家詳細介紹了iOS自定義日歷控件的簡單實現(xiàn)過程,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2016-09-09
  • iOS開發(fā)教程之識別圖片中二維碼功能的實現(xiàn)

    iOS開發(fā)教程之識別圖片中二維碼功能的實現(xiàn)

    長按識別二維碼這個功能相信對大家來說都不陌生,最近工作中就遇到了這個需求,所以下面這篇文章主要給大家介紹了關于利用iOS識別圖片中二維碼的相關資料,文中通過示例代碼介紹的非常詳細,需要的朋友可以參考下
    2018-07-07
  • MAC系統(tǒng)下安裝FFmpeg的圖文教程

    MAC系統(tǒng)下安裝FFmpeg的圖文教程

    這篇文章主要給大家介紹了關于如何在MAC系統(tǒng)下安裝FFmpeg的相關資料,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面來一起學習學習吧
    2019-03-03
  • iOS開發(fā)自定義頁腳和頁眉技巧詳解

    iOS開發(fā)自定義頁腳和頁眉技巧詳解

    這篇文章主要為大家介紹了iOS開發(fā)自定義頁腳和頁眉的技巧示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2022-07-07
  • iOS開發(fā)中判斷字符串為空的方法

    iOS開發(fā)中判斷字符串為空的方法

    判斷字符串為空,看著很簡單,其實不然,下面通過本篇文章給大家介紹了iOS開發(fā)中判斷字符串為空的方法,需要的朋友可以參考下
    2017-12-12
  • Swift和Objective-C 混編注意事項

    Swift和Objective-C 混編注意事項

    這篇文章主要介紹了Swift和Objective-C 混編注意事項的相關資料,需要的朋友可以參考下
    2016-10-10
  • iOS實現(xiàn)手指點擊出現(xiàn)波紋的效果

    iOS實現(xiàn)手指點擊出現(xiàn)波紋的效果

    最近在閑暇的時間做了一個反饋手指點擊屏幕的效果,用到了CAShapeLayer和基本的動畫知識,實現(xiàn)的效果很贊,這種效果使用在某些頁面上肯定會給用戶更有趣的體驗,特別是面向兒童的app中。文中給出了詳細的示例代碼,感興趣的朋友們下面來一起看看吧。
    2016-12-12
  • iOS 真機調(diào)試微信小程序

    iOS 真機調(diào)試微信小程序

    下面介紹下如何使用 Xcode、Reveal 和 Safari 來真機調(diào)試 iOS 上的小程序。感興趣的朋友跟隨腳本之家小編一起看看吧
    2018-08-08

最新評論