通過CAShaperLayer把UIView做成鏤空效果

在做公司項(xiàng)目過程中,有時(shí)我們會(huì)遇到一個(gè)視圖中間是鏤空的效果,首先,我們可能想到的是在四周創(chuàng)建一些視圖,中間是空的。那么,我們有沒有簡單方法呢?下面,就小編給大家介紹一下CAShaperLayer是怎么給UIView做成鏤空效果吧。
話不多說,直接上代碼!
我們?cè)诳刂破饕晥D上加個(gè)view,控制器視圖的顏色是黑色,添加的view顏色是紅色

- (void)viewDidLoad {
    [super viewDidLoad];
    self.view.backgroundColor = [UIColor blackColor];
 
    UIView *view = [[UIView alloc]init];
    view.frame = self.view.bounds;
    view.backgroundColor = [UIColor redColor];
    [self.view addSubview:view];
    
    CGFloat W = self.view.frame.size.width;
    CGFloat H = self.view.frame.size.height;
    CAShapeLayer *shperLayer = [[CAShapeLayer alloc]init];
    CGMutablePathRef path = CGPathCreateMutable();
    // 保留頂部100
    CGPathAddRect(path, nil, CGRectMake(0, 0, W, 100));
    // 保留底部100
    CGPathAddRect(path, nil, CGRectMake(0, H - 100, W, 100));
    shperLayer.path = path;
    self.view.layer.mask = shperLayer;
    // 之前沒有釋放path,更新一下。注意:在Swift中CGMutablePathRef是class不需要手動(dòng)釋放
    CGPathRelease(path);
}

運(yùn)行后的效果

大家可以看到運(yùn)行后中間是黑色,上下是紅色。


運(yùn)行后的效果

以上是對(duì)CAShapeLayer的簡單使用,后期會(huì)給大家介紹CAShapeLayer的更多使用。

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時(shí)請(qǐng)結(jié)合常識(shí)與多方信息審慎甄別。
平臺(tái)聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡書系信息發(fā)布平臺(tái),僅提供信息存儲(chǔ)服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

  • 聲明:本來自己搞這篇文章是為了以后開發(fā)時(shí)自己用的,但是不知道為什么被簡書推送到專題里面了.這篇文章不是我原創(chuàng)的,是...
    名揚(yáng)丶四海閱讀 909評(píng)論 0 1
  • 發(fā)現(xiàn) 關(guān)注 消息 iOS 第三方庫、插件、知名博客總結(jié) 作者大灰狼的小綿羊哥哥關(guān)注 2017.06.26 09:4...
    肇東周閱讀 15,161評(píng)論 4 61
  • Android 自定義View的各種姿勢1 Activity的顯示之ViewRootImpl詳解 Activity...
    passiontim閱讀 178,881評(píng)論 25 709
  • 只有它,值得你花一生去學(xué)習(xí) 我們做過最蠢的事情,大概就是把最好的脾氣給別人,而把最壞的脾氣留給了家人。 好像貓叔說...
    小秦哥哥閱讀 267評(píng)論 2 4
  • 在云霧山間有一處道觀,道觀名約白云觀是師祖賀心師太在世的時(shí)候建造的,到現(xiàn)在的慧園師太也有個(gè)四、五代了。 這白云觀大...
    良曉諾閱讀 448評(píng)論 0 1

友情鏈接更多精彩內(nèi)容