怎么给IOS视图控件加上一层虚线边框 还是可以根据控件大小来定呢?
应用场景: 一个文本textField跟要据文字大小来改变自己的大小。 边框为虚线边框。
这时候大家可能考虑到的是 做一个虚线背景 然后拉伸后做为textField的边框。
想法很好,但出现的总是是, 在拉伸的那个点,正好是白色 或 者黑色的时候 就是有总是的。 白色拉伸后一长条全是白的 黑色也如此
这时候在考虑的就是 能不能实时画一个虚线背景图 实时设置textField的背景呢。
答案是可以的。
我也在网上找了一些相关的资料 发现零零散散的也这方面的东西 但没有人贴出一个完整可用的解决方案
因此 我写了一个UIImage的分类。 可以直接调用一下 就可以直接使用了。
代码:
+ (UIImage*)imageWithSize:(CGSize)size borderColor:(UIColor *)color borderWidth:(CGFloat)borderWidth { UIGraphicsBeginImageContextWithOptions(size, NO, 0.0); [[UIColor clearColor] set]; CGContextRef context = UIGraphicsGetCurrentContext(); CGContextBeginPath(context); CGContextSetLineWidth(context, borderWidth); CGContextSetStrokeColorWithColor(context, color.CGColor); CGFloat lengths[] = { 3, 1 }; CGContextSetLineDash(context, 0, lengths, 1); CGContextMoveToPoint(context, 0.0, 0.0); CGContextAddLineToPoint(context, size.width, 0.0); CGContextAddLineToPoint(context, size.width, size.height); CGContextAddLineToPoint(context, 0, size.height); CGContextAddLineToPoint(context, 0.0, 0.0); CGContextStrokePath(context); UIImage* image = UIGraphicsGetImageFromCurrentImageContext(); UIGraphicsEndImageContext(); return image; }
这是方法的实现。 第一个参数为 需要虚线边框视图的大小, 第二个为 边框颜色, 第三个为 边框粗细。
创建为UIImage的分类的话 直接可以用UIImage 来调用 非常方便。
原创文章,转载请注明出处!