根据UIColor生成图片

作者: 莱姆船长 | 来源:发表于2018-05-16 17:26 被阅读8次

根据UIColor生成一个可以带任意圆角的图片

.h 文件

#import <UIKit/UIKit.h>

@interface UIImage (LGFColorImage)

#pragma mark - 生成一个平面颜色圆角可缩放图像
/**
 @param cornerRadius 圆角半径
 @param cornerColor  圆角被截取部分填充色
 @param fillColor    背景填充色
 */
+ (UIImage *)lgf_ColorImageWithCornerRadius:(CGFloat)cornerRadius
                                          cornerColor:(UIColor *)cornerColor
                                            fillColor:(UIColor *)fillColor;

#pragma mark - 生成具有边框的平面颜色圆角可缩放图像
/**
 @param cornerRadius 圆角半径
 @param cornerColor  圆角被截取部分填充色
 @param fillColor    背景填充色
 @param borderColor  边框颜色
 @param borderWidth  边框宽度
 */
+ (UIImage *)lgf_ColorImageWithCornerRadius:(CGFloat)cornerRadius
                                          cornerColor:(UIColor *)cornerColor
                                            fillColor:(UIColor *)fillColor
                                          borderColor:(UIColor *)borderColor
                                          borderWidth:(CGFloat)borderWidth;

#pragma mark - 生成具有边框的平面颜色圆角可缩放图像
/**
 @param cornerRadius    圆角半径
 @param cornerColor     圆角被截取部分填充色
 @param fillColor       背景填充色
 @param borderColor     边框颜色
 @param borderWidth     边框宽度
 @param roundedCorners  设置圆角个数 和 位置 (UIRectCornerTopLeft | UIRectCornerBottomRight | UIRectCornerTopRight | UIRectCornerBottomLeft)
 @param scale           每个点的缩放像素密度. 设置 0 为和当前屏幕一样.
 */
+ (UIImage *)lgf_ColorImageWithCornerRadius:(CGFloat)cornerRadius
                                          cornerColor:(UIColor *)cornerColor
                                            fillColor:(UIColor *)fillColor
                                          borderColor:(UIColor *)borderColor
                                          borderWidth:(CGFloat)borderWidth
                                       roundedCorners:(UIRectCorner)roundedCorners
                                                scale:(CGFloat)scale;

@end

.m 文件

#import "UIImage+LGFColorImage.h"

@implementation UIImage (LGFColorImage)

#pragma mark - 生成一个平面颜色圆角可缩放图像
/**
 @param cornerRadius 圆角半径
 @param cornerColor  圆角被截取部分填充色
 @param fillColor    背景填充色
 */
+ (UIImage *)lgf_ColorImageWithCornerRadius:(CGFloat)cornerRadius
                                          cornerColor:(UIColor *)cornerColor
                                            fillColor:(UIColor *)fillColor {
    return [self lgf_ColorImageWithCornerRadius:cornerRadius
                                              cornerColor:cornerColor
                                                fillColor:fillColor
                                              borderColor:nil
                                              borderWidth:1.0
                                           roundedCorners:UIRectCornerAllCorners
                                                    scale:0.0];
}

#pragma mark - 生成具有边框的平面颜色圆角可缩放图像
/**
 @param cornerRadius 圆角半径
 @param cornerColor  圆角被截取部分填充色
 @param fillColor    背景填充色
 @param borderColor  边框颜色
 @param borderWidth  边框宽度
 */
+ (UIImage *)lgf_ColorImageWithCornerRadius:(CGFloat)cornerRadius
                                          cornerColor:(UIColor *)cornerColor
                                            fillColor:(UIColor *)fillColor
                                          borderColor:(UIColor *)borderColor
                                          borderWidth:(CGFloat)borderWidth {
    return [self lgf_ColorImageWithCornerRadius:cornerRadius
                                              cornerColor:cornerColor
                                                fillColor:fillColor
                                              borderColor:borderColor
                                              borderWidth:borderWidth
                                           roundedCorners:UIRectCornerAllCorners
                                                    scale:0.0];
}

#pragma mark - 生成具有边框的平面颜色圆角可缩放图像
/**
 @param cornerRadius    圆角半径
 @param cornerColor     圆角被截取部分填充色
 @param fillColor       背景填充色
 @param borderColor     边框颜色
 @param borderWidth     边框宽度
 @param roundedCorners  设置圆角个数 和 位置 (UIRectCornerTopLeft | UIRectCornerBottomRight | UIRectCornerTopRight | UIRectCornerBottomLeft)
 @param scale           每个点的缩放像素密度. 设置 0 为和当前屏幕一样.
 */
+ (UIImage *)lgf_ColorImageWithCornerRadius:(CGFloat)cornerRadius
                                          cornerColor:(UIColor *)cornerColor
                                            fillColor:(UIColor *)fillColor
                                          borderColor:(UIColor *)borderColor
                                          borderWidth:(CGFloat)borderWidth
                                       roundedCorners:(UIRectCorner)roundedCorners
                                                scale:(CGFloat)scale {
    static NSCache *__pathCache = nil;
    static dispatch_once_t onceToken;
    dispatch_once(&onceToken, ^{
        __pathCache = [[NSCache alloc] init];
        __pathCache.countLimit = 20;
    });
    
    if ([cornerColor isEqual:[UIColor clearColor]]) {
        cornerColor = nil;
    }
    
    CGFloat dimension = (cornerRadius * 2) + 1;
    CGRect bounds = CGRectMake(0, 0, dimension, dimension);
    
    typedef struct {
        UIRectCorner corners;
        CGFloat radius;
    } PathKey;
    PathKey key = { roundedCorners, cornerRadius };
    NSValue *pathKeyObject = [[NSValue alloc] initWithBytes:&key objCType:@encode(PathKey)];
    
    CGSize cornerRadii = CGSizeMake(cornerRadius, cornerRadius);
    UIBezierPath *path = [__pathCache objectForKey:pathKeyObject];
    if (path == nil) {
        path = [UIBezierPath bezierPathWithRoundedRect:bounds byRoundingCorners:roundedCorners cornerRadii:cornerRadii];
        [__pathCache setObject:path forKey:pathKeyObject];
    }
    UIGraphicsBeginImageContextWithOptions(bounds.size, cornerColor != nil, scale);
    BOOL contextIsClean = YES;
    if (cornerColor) {
        contextIsClean = NO;
        [cornerColor setFill];
        UIRectFillUsingBlendMode(bounds, kCGBlendModeCopy);
    }
    
    BOOL canUseCopy = contextIsClean || (CGColorGetAlpha(fillColor.CGColor) == 1);
    [fillColor setFill];
    [path fillWithBlendMode:(canUseCopy ? kCGBlendModeCopy : kCGBlendModeNormal) alpha:1];
    
    if (borderColor) {
        [borderColor setStroke];
        CGRect strokeRect = CGRectInset(bounds, borderWidth / 2.0, borderWidth / 2.0);
        UIBezierPath *strokePath = [UIBezierPath bezierPathWithRoundedRect:strokeRect
                                                         byRoundingCorners:roundedCorners
                                                               cornerRadii:cornerRadii];
        [strokePath setLineWidth:borderWidth];
        BOOL canUseCopy = (CGColorGetAlpha(borderColor.CGColor) == 1);
        [strokePath strokeWithBlendMode:(canUseCopy ? kCGBlendModeCopy : kCGBlendModeNormal) alpha:1];
    }
    
    UIImage *result = UIGraphicsGetImageFromCurrentImageContext();
    UIGraphicsEndImageContext();
    
    UIEdgeInsets capInsets = UIEdgeInsetsMake(cornerRadius, cornerRadius, cornerRadius, cornerRadius);
    result = [result resizableImageWithCapInsets:capInsets resizingMode:UIImageResizingModeStretch];
    
    return result;
}

@end

相关文章

网友评论

    本文标题:根据UIColor生成图片

    本文链接:https://www.haomeiwen.com/subject/kvcmdftx.html