先来张效果图
/* 自定义的方法, 实际使用时的传入参数以自己需求为准 */
- (void)addLayerWith:(UIView *)view {
/* 初始化一个layer */
CAShapeLayer *border = [CAShapeLayer layer];
/* 虚线的颜色 */
border.strokeColor = [UIColor whiteColor].CGColor;
/* 填充虚线内的颜色 */
border.fillColor = nil;
/* 贝塞尔曲线路径 */
border.path = [UIBezierPath bezierPathWithRect:CGRectMake(4, 4, view.frame.size.width- 8, view.frame.size.height - 8)].CGPath;
/* 虚线宽度 */
border.lineWidth = 0.7f;
//border.frame = view.bounds; /* 这个因为给了路径, 而且用的约束给的控件尺寸, 所以没什么效果 */
/* 官方API注释:The cap style used when stroking the path. Options are `butt', `round'
* and `square'. Defaults to `butt'. */
/* 意思是沿路径画帽时的样式 有三种 屁股 ; 圆; 广场 ,我没感觉有啥区别 可以自己试一下*/
border.lineCap = @"square";
/* 虚线的每个点长 和 两个点之间的空隙 */
border.lineDashPattern = @[@3, @2];
/* 添加到你的控件上 */
[view.layer addSublayer:border];
}
版权声明:本文为qq_30402119原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。