码迷,mamicode.com
首页 > 其他好文 > 详细

一个UILabel不同部分显示不同颜色

时间:2016-12-02 03:11:58      阅读:123      评论:0      收藏:0      [点我收藏+]

标签:gets   attr   http   test   nbsp   表格   form   name   eof   

我们直接来看效果图吧:

技术分享

 

需求:就是表格cell里面的状态Label,前面的“状态:”是黑色,后面的状态值是红色,他们在同一个Label上,怎么做呢?

解答:真的是会者不难,难者不会啊,使用富文本,轻松搞定。

费话不多说,直接上代码:

 1 // 根据状态值合成富文本
 2 - (NSMutableAttributedString *)getStateString:(NSString *)state{
 3 
 4     // 合成后的字符串
 5     NSString *fullStr = [NSString stringWithFormat:@"状态:%@",state];
 6 
 7     // 状态值的Range
 8     NSRange range = [fullStr rangeOfString:state];
 9     
10     // 状态值显示的颜色
11     UIColor *color = [UIColor kt_colorWithHex:0xff1e00 andAlpha:1];
12     
13     // 将合成后的字符串转换为富文本
14     NSMutableAttributedString *attributedStr = [[NSMutableAttributedString alloc] initWithString:fullStr];
15 
16     // 给对应的range添加属性
17     [attributedStr addAttributes:@{NSForegroundColorAttributeName:color} range:range];
18     
19     return attributedStr;
20 }

然后直接将富文本赋值给Label的attributedText

1 self.stateLabel.attributedText = [self getStateString:@"未接单"];

 

一个UILabel不同部分显示不同颜色

标签:gets   attr   http   test   nbsp   表格   form   name   eof   

原文地址:http://www.cnblogs.com/panda1024/p/6124046.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!