iOS开发技巧(系列十八:扩展UIColor,支持十六进制颜色设置)

转载 2015年07月10日 23:29:12

可以直接使用十六进制设置控件的颜色,而不必通过除以255.0进行转换


新建一个Category,命名为UIColor+Hex,表示UIColor支持十六进制Hex颜色设置。

UIColor+Hex.h文件,

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
#import <UIKit/UIKit.h>
 
#define RGBA_COLOR(R, G, B, A) [UIColor colorWithRed:((R) / 255.0f) green:((G) / 255.0f) blue:((B) / 255.0f) alpha:A]
#define RGB_COLOR(R, G, B) [UIColor colorWithRed:((R) / 255.0f) green:((G) / 255.0f) blue:((B) / 255.0f) alpha:1.0f]
 
@interface UIColor (Hex)
 
+ (UIColor *)colorWithHexString:(NSString *)color;
 
//从十六进制字符串获取颜色,
//color:支持@“#123456”、 @“0X123456”、 @“123456”三种格式
+ (UIColor *)colorWithHexString:(NSString *)color alpha:(CGFloat)alpha;
 
@end

上面的代码在开头是两个宏定义,就是对[UIColor colorWithRed:green:blue:alpha]方法的简化,在UIColor(Hex)中声明两个方法-colorWithHexString和-colorWithHexString:alpha,这个很好理解。

UIColor+Hex.m文件

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
#import "UIColor+Hex.h"
 
@implementation UIColor (Hex)
 
+ (UIColor *)colorWithHexString:(NSString *)color alpha:(CGFloat)alpha
{
    //删除字符串中的空格
    NSString *cString = [[color stringByTrimmingCharactersInSet:[NSCharacterSet whitespaceAndNewlineCharacterSet]] uppercaseString];
    // String should be 6 or 8 characters
    if ([cString length] < 6)
    {
        return [UIColor clearColor];
    }
    // strip 0X if it appears
    //如果是0x开头的,那么截取字符串,字符串从索引为2的位置开始,一直到末尾
    if ([cString hasPrefix:@"0X"])
    {
        cString = [cString substringFromIndex:2];
    }
    //如果是#开头的,那么截取字符串,字符串从索引为1的位置开始,一直到末尾
    if ([cString hasPrefix:@"#"])
    {
        cString = [cString substringFromIndex:1];
    }
    if ([cString length] != 6)
    {
        return [UIColor clearColor];
    }
     
    // Separate into r, g, b substrings
    NSRange range;
    range.location = 0;
    range.length = 2;
    //r
    NSString *rString = [cString substringWithRange:range];
    //g
    range.location = 2;
    NSString *gString = [cString substringWithRange:range];
    //b
    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:alpha];
}
 
//默认alpha值为1
+ (UIColor *)colorWithHexString:(NSString *)color
{
    return [self colorWithHexString:color alpha:1.0f];
}
 
@end

这样就扩展了UIColor,支持十六进制颜色设置。下面举个栗子,设置UIButton一些颜色特征,来说明该扩展的使用,

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
#import "UIColor+Hex.h"
//省略多余的代码
 
//设置导航栏右侧的BarButtonItem为Button
- (void)setupNavigationItem
{   
    UIView *rightView = [[UIView alloc] init];
    rightView.bounds = CGRectMake(0, 0, 52, 44);
     
    UIButton *rightButton = [UIButton buttonWithType:UIButtonTypeCustom];
    rightButton.frame = CGRectMake(-6, 0, 52, 44);
    rightButton.backgroundImageEdgeInsets = UIEdgeInsetsMake(7, 0, 7, 0);
    //kSetting是国际化的字符串"设置"
    [rightButton setTitle:NVSLocalizedString(@"kSetting", nil) forState:UIControlStateNormal];
    //使用宏定义的RGB_COLOR
//    [rightButton setTitleColor:RGB_COLOR(160, 170, 150) forState:UIControlStateHighlighted];
    //使用UIColor+Hex扩展
    [rightButton setTitleColor:[UIColor colorWithHexString:@"#708c3b"] forState:UIControlStateNormal];
    rightButton.titleLabel.font = [UIFont fontWithName:@"Heiti SC" size:12.f];
    [rightButton setBackgroundImage:[UIImage imageNamed:@"device_setting_bg"]
                           forState:UIControlStateNormal];
    [rightButton setBackgroundImage:[UIImage imageNamed:@"device_setting_bg_press"]
                           forState:UIControlStateHighlighted];
    [rightButton addTarget:self action:@selector(settingBtnPresss:)
          forControlEvents:UIControlEventTouchUpInside];
    [rightView addSubview:rightButton];
     
    UIBarButtonItem *rightBarButtonItem = [[UIBarButtonItem alloc] initWithCustomView:rightView];
    [self.navigationItem setRightBarButtonItem:rightBarButtonItem animated:YES];
  
    [rightBarButtonItem release];
    [rightView release];
}

恩,使用差不多就这么简单,总结一下,本篇博客主要有以下几个细节或者说知识点,

(1)宏定义RGB_COLOR和RGBA_COLOR可以设置颜色

(2)UIColor+Hex扩展可以设置颜色

(3)导航栏上面的BarButtonItem怎么设置为Button

(4)Button一些常用和不常用的属性设置




原文链接:http://my.oschina.net/leejan97/blog/307491

相关文章推荐

iOS开发之UIColor类拓展,可通过上百种颜色名字生成颜色 可通过十六进制生成颜色

CJColorExample CJColor - a easy way to use UIColor by color name, RGB, HEXString Author:CoderChenJun...

iPhone开发 – 小技巧二则 (UIColor 16进制颜色 | UIview设置frame)

引言 开发中总遇到各种各样的问题,解决方法也各有各的不同,可以说是条条大路通罗马,但是总有一条或几条是最优的,开始的时候我们可能只是为了完成去罗马的任务,但是罗马去多了以后,总会发现些捷径,既然有捷...

iOS开发:APP设置颜色时候直接使用十六进制、RGB色值设置颜色

在APP开发过程中,有些时候需要自定义颜色,而且UI给的颜色的色值要么是十六进制的,要么是RGB的,这样如果没有使用相关的转换方法是不能直接使用的,那么下面就简单说一下这两种方式转换的使用方式,掌握之...

iOS开发技巧-使用storyboard和代码设置RGB颜色

如何使用代码和storyboard设置 颜色为16进制的? 我们在做真是的项目时常常是美工给我做好 效果图,标尺图我们再来 写UI的,当然这些标尺图中也包括 设置 颜色,一般美工给你的 颜色是 一个 ...

UIColor 类扩展支持十六进制

UIColor 类扩展支持十六进制

iOS开发是否需要缓存UIColor

在开发中,发现有的项目对 UIColor 对象进行了缓存。个人感觉,对于 UIColor 这样的对象,其本身记录的信息有限,创建它应该不会对APP性能产生显著的影响的,为此特别写了一个 Demo 验证...

iOS开发技巧(系列十三:UIRefreshControl下拉刷新)

接上篇UIRefreshControl系统下拉刷新,又找了一篇不错的博客 ,分享给大家转载地址:http://my.oschina.net/leejan97/blog/268411 其实UIRefr...

ios开发UI系列之使用AutoLayout的几个经典的布局技巧

在UI的开发中,会遇到各种五花八门的布局需求,本文简单介绍几种常用且具有代表性的布局及技巧,供读者参考. 常用布局1: 图片与间距的布局  (图1-1) 如图,在UI的开发中,对一个页面中好几张图片进...

iOS开发技巧系列---打造强大的BaseModel

iOS开发技巧系列—打造强大的BaseModel 摘要: 从事iOS开发已经两年了,从一无所知到现在能独立带领团队完成一系列APP的开发.网络上的大神给了我太多的帮助,他们无私地贡献自己的心得...
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:深度学习:神经网络中的前向传播和反向传播算法推导
举报原因:
原因补充:

(最多只允许输入30个字)