iOS 部分圆角+边框的实现(防边框被切)
部分圆角可以通过 layer 的 mask 属性实现。
1. 创建 UIBezierPath
关键参数 corners
,由于是 NS_OPTIONS
枚举,所以可以使用位运算来达到设置多个圆角。
1 /* corners 的可能值 2 typedef NS_OPTIONS(NSUInteger, UIRectCorner) { 3 UIRectCornerTopLeft = 1 << 0, 4 UIRectCornerTopRight = 1 << 1, 5 UIRectCornerBottomLeft = 1 << 2, 6 UIRectCornerBottomRight = 1 << 3, 7 UIRectCornerAllCorners = ~0UL 8 }; 9 */ 10 UIBezierPath *path = [UIBezierPath bezierPathWithRoundedRect:view.bounds byRoundingCorners:corners cornerRadii:CGSizeMake(cornerRadius, cornerRadius)];
2. 创建 maskLayer
view.layer.mask
属性会按照赋值的 layer
的 alpha
通道来遮盖 view
的 layer
,即 alpha
为0的部分会被隐藏。
1 CAShapeLayer *maskLayer = [CAShapeLayer layer]; 2 maskLayer.frame = view.bounds; 3 maskLayer.path = path.CGPath; 4 view.layer.mask = maskLayer;
如果在添加了部分圆角之后,如果想要添加边框,就不能使用 view.layer.cornerRadius
属性来实现,圆角部分会被裁剪。可以通过添加一层 subLayer
来实现。
3. 创建边框 layer
还可以通过修CAShapeLayer
与line
相关的属性,来改创建不同样式的边框。
1 CAShapeLayer *borderLayer = [CAShapeLayer layer]; 2 borderLayer.frame = view.bounds; 3 borderLayer.path = path.CGPath; 4 borderLayer.lineWidth = borderWidth; 5 borderLayer.fillColor = [UIColor clearColor].CGColor; 6 borderLayer.strokeColor = borderColor.CGColor; 7 [view.layer addSublayer:borderLayer];
4. 效果
作者:Mokyz
链接:https://www.jianshu.com/p/b7cae1208362
来源:简书
让明天,不后悔今天的所作所为
posted on 2021-02-22 14:55 Sinner_Yun 阅读(1465) 评论(0) 编辑 收藏 举报