iOS 在控件上添加虚线边框
2017-03-15 本文已影响2695人
闹钟先生的闹钟
以按钮为例子,实现虚线按钮:
CAShapeLayer *border = [CAShapeLayer layer];
//虚线的颜色
border.strokeColor = [UIColor redColor].CGColor;
//填充的颜色
border.fillColor = [UIColor clearColor].CGColor;
//设置路径
border.path = [UIBezierPath bezierPathWithRect:self.lineButton.bounds].CGPath;
border.frame = self.lineButton.bounds;
//虚线的宽度
border.lineWidth = 1.f;
//设置线条的样式
// border.lineCap = @"square";
//虚线的间隔
border.lineDashPattern = @[@4, @2];
[self.lineButton.layer addSublayer:border];
data:image/s3,"s3://crabby-images/cd24c/cd24c643eb2666fe4c946057230aa253d868825f" alt=""
到这里基本已经OK了,但是突然发现我要的是有圆角的按钮,那就去添加圆角
border.cornerRadius = 5.f;
border.masksToBounds = YES;
然而效果是这样子的,四个角变的很奇怪
data:image/s3,"s3://crabby-images/011bf/011bf0be174fee545e5b7dfe9ea3813759691d04" alt=""
以为要在控件上添加圆角
self.lineButton.layer.cornerRadius = 5.f;
self.lineButton.layer.masksToBounds = YES;
然而效果依然很奇怪。
data:image/s3,"s3://crabby-images/5d09d/5d09d739cc4891e68c55a7abbe38ef6c162b7127" alt=""
最后找资料终于得到实现效果 需要把bezierPathWithRect 替换成 bezierPathWithRoundedRect 就可以了
data:image/s3,"s3://crabby-images/bca63/bca634738793abac411a2b3456123d336653bf9b" alt=""
下面全部代码
CAShapeLayer *border = [CAShapeLayer layer];
//虚线的颜色
border.strokeColor = [UIColor redColor].CGColor;
//填充的颜色
border.fillColor = [UIColor clearColor].CGColor;
UIBezierPath *path = [UIBezierPath bezierPathWithRoundedRect:self.lineButton.bounds cornerRadius:5];
//设置路径
border.path = path.CGPath;
border.frame = self.lineButton.bounds;
//虚线的宽度
border.lineWidth = 1.f;
//设置线条的样式
// border.lineCap = @"square";
//虚线的间隔
border.lineDashPattern = @[@4, @2];
self.lineButton.layer.cornerRadius = 5.f;
self.lineButton.layer.masksToBounds = YES;
[self.lineButton.layer addSublayer:border];