切圓角

四個(gè)不同的圓角
        _menuView = [[UIView alloc] initWithFrame:CGRectMake(12, menuViewY, KScreenWidth -24, 51)];
        _menuView.backgroundColor = [UIColor cyanColor];
        CGSize size = _menuView.size;
        CGFloat imgW = size.width;
        CGFloat imgH = size.height;
        CGFloat downLeft = 5;
        CGFloat upLeft = 10;
        UIBezierPath *path = [UIBezierPath bezierPath];
        //左下
        [path addArcWithCenter:CGPointMake(downLeft, imgH - downLeft) radius:downLeft startAngle:M_PI_2 endAngle:M_PI clockwise:YES];
        //左上
        [path addArcWithCenter:CGPointMake(upLeft, upLeft) radius:upLeft startAngle:M_PI endAngle:M_PI_2 * 3 clockwise:YES];
        //右上
        [path addArcWithCenter:CGPointMake(imgW - upLeft, upLeft) radius:upLeft startAngle:M_PI_2 * 3 endAngle:0 clockwise:YES];
        //右下
        [path addArcWithCenter:CGPointMake(imgW - downLeft, imgH - downLeft) radius:downLeft startAngle:0 endAngle:M_PI_2 clockwise:YES];
        [path closePath];

        CAShapeLayer *maskLayer = [[CAShapeLayer alloc] init];
        maskLayer.frame = _menuView.bounds;
        maskLayer.path = path.CGPath;
        _menuView.layer.mask = maskLayer;
不同方位的圓角
    UIBezierPath *maskPath = [UIBezierPath bezierPathWithRoundedRect:self.bounds
                                                   byRoundingCorners:corner
                                                         cornerRadii:CGSizeMake(cornerRadii,
                                                                                cornerRadii)];
    CAShapeLayer *maskLayer = [[CAShapeLayer alloc] init];
    maskLayer.frame = self.bounds;
    maskLayer.path = maskPath.CGPath;
    self.layer.mask = maskLayer;

原文地址
git地址

最后編輯于
?著作權(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)容

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