在作iOS开发时,通常咱们会吸色,就是产品给的图咱们通常会吸色,可是最近吸色时候,老大说有较大的颜色误差,因此要求咱们直接使用UI给出的额16进制颜色,你也能够搜索《RGB颜色值转换成十六进制颜色码:》先把16进制颜色转换为RGB的而后再写,可是这样有点影响开发速度,因此呢就写了一个UIColor的分类,直接使用16进制的颜色。spa
UIColor的分类DLColorChange .h文件
#import <UIKit/UIKit.h> @interface UIColor (DLColorChange) // 颜色转换:iOS中(以#开头)十六进制的颜色转换为UIColor(RGB) + (UIColor *) colorWithHexString: (NSString *)color; @end
UIColor的分类DLColorChange .m文件
#import "UIColor+DLColorChange.h" @implementation UIColor (DLColorChange) + (UIColor *) colorWithHexString: (NSString *)color { NSString *cString = [[color stringByTrimmingCharactersInSet:[NSCharacterSet whitespaceAndNewlineCharacterSet]] uppercaseString]; // String should be 6 or 8 characters if ([cString length] < 6) { return [UIColor clearColor]; } // 判断前缀 if ([cString hasPrefix:@"0X"]) cString = [cString substringFromIndex:2]; if ([cString hasPrefix:@"#"]) cString = [cString substringFromIndex:1]; if ([cString length] != 6) return [UIColor clearColor]; // 从六位数值中找到RGB对应的位数并转换 NSRange range; range.location = 0; range.length = 2; //R、G、B NSString *rString = [cString substringWithRange:range]; range.location = 2; NSString *gString = [cString substringWithRange:range]; range.location = 4; NSString *bString = [cString substringWithRange:range]; // Scan values unsigned int r, g, b; [[NSScanner scannerWithString:rString] scanHexInt:&r]; [[NSScanner scannerWithString:gString] scanHexInt:&g]; [[NSScanner scannerWithString:bString] scanHexInt:&b]; return [UIColor colorWithRed:((float) r / 255.0f) green:((float) g / 255.0f) blue:((float) b / 255.0f) alpha:1.0f]; } @end
咱们能够把code
#import "UIColor+DLColorChange.h"
写在pch文件中,这样咱们全局就能够用。调用以下blog
self.view.backgroundColor=[UIColor colorWithHexString:@"#edae48"];