绘制圆角边框、文字 生成图片

2020-03-16  本文已影响0人  wustzhy
// 创建"边框、文字" 图
+ (UIImage *)zy_imageWithBorderColor:(UIColor *)bColor borderWidth:(CGFloat)borderWidth borderRadius:(CGFloat)borderRadius text:(NSString *)text textColor:(UIColor *)tColor font:(UIFont *)font inset:(UIEdgeInsets)inset; {
    
    CGSize textSize = [text sizeWithFont:font maxW:MAXFLOAT];
    CGSize innerSize = CGSizeMake(inset.left + textSize.width + inset.right, inset.top + textSize.height + inset.bottom);
    CGRect textFrame = CGRectMake(inset.left + borderWidth, inset.top + borderWidth, textSize.width, textSize.height);
    
    CGRect outRoundFrame = CGRectMake(0, 0, innerSize.width + 2*borderWidth, innerSize.height + 2*borderWidth);
    // 用UIGraphics进行2D图像渲染 不要用UIGraphicsBeginImageContext(size); 不然图片会模糊
    UIGraphicsBeginImageContextWithOptions(outRoundFrame.size, NO, 0.0);
    
    CGContextRef contextRef = UIGraphicsGetCurrentContext();
    CGContextSetBlendMode(contextRef, kCGBlendModeCopy);
    // 设置透明背景色
    CGContextSetFillColorWithColor(contextRef, [UIColor clearColor].CGColor);
    CGContextFillRect(contextRef, outRoundFrame);
    
    // 画外矩形
    {
        CGPathRef pathRef = CGPathCreateWithRoundedRect(outRoundFrame, borderWidth+borderRadius, borderWidth+borderRadius, NULL);
        CGContextAddPath(contextRef, pathRef);
        CGPathRelease(pathRef);
        CGContextSetFillColorWithColor(contextRef, bColor.CGColor);
        CGContextFillPath(contextRef);
    }
    
    // 有边框,画内矩形
    CGPathRef pathRef = CGPathCreateWithRoundedRect(CGRectMake(borderWidth, borderWidth, innerSize.width, innerSize.height),
                                                    borderRadius,
                                                    borderRadius,
                                                    NULL);
    CGContextAddPath(contextRef, pathRef);
    CGPathRelease(pathRef);
    CGContextSetFillColorWithColor(contextRef, [UIColor clearColor].CGColor);
    CGContextFillPath(contextRef);
    
    NSDictionary *attr = @{NSFontAttributeName: font, NSForegroundColorAttributeName : tColor };
    //位置显示
    [text drawInRect:textFrame withAttributes:attr];
    
    UIImage *aimg = UIGraphicsGetImageFromCurrentImageContext();
    UIGraphicsEndImageContext();
    return aimg;
    
}

思路
1、画布 width、height,
2、外圆角矩形 width、height,使用边框颜色color
3、若边框宽度1,那么内圆角矩形 width-12、height-12,透明色
这样就可以画出边框宽度为1、color色的(width, height)矩形

部分参数说明
  inset:文字和边框距离
  

为什么不使用bezierPath呢,因为这篇文章 有讲,bezierPath提供的api绘制圆角矩形,圆角处模糊严重。

上一篇 下一篇

猜你喜欢

热点阅读