码迷,mamicode.com
首页 > 移动开发 > 详细

IOS中获取label中文本的高度及tableviewCell的自适应

时间:2015-09-28 20:59:07      阅读:303      评论:0      收藏:0      [点我收藏+]

标签:

1.NSString有个方法,可以获取字符串实际所占高度和宽度。可以用到UITableViewCell的自适应上
在IOS7之前,用下边的

- (CGSize)sizeWithFont:(UIFont *)font constrainedToSize:(CGSize)size lineBreakMode:(NSLineBreakMode)lineBreakMode;

是用来获取文本内容在指定的size内,算出所需要的实际宽度和高度。如

//这是获取字符串在指定的size内(宽度超过175,则换行),所需要的宽度和高度。
CGSize maxSize = CGSizeMake(175, MAXFLOAT);
CGSize size = [@"这是测试的数据" sizeWithFont:[UIFont systemFontOfSize:14] constrainedToSize:maxSize lineBreakMode:NSLineBreakByWordWrapping];
//字符串所占高度
CGFloat labelHeight = size.height;

在IOS7和之后的版本,sizeWithFont方法就过时了。用

- (CGRect)boundingRectWithSize:(CGSize)size options:(NSStringDrawingOptions)options attributes:(NSDictionary *)attributes context:(NSStringDrawingContext *)context
代替。

NSString *strTest = @"这是一段测试数据";
NSMutableParagraphStyle *paragraphStyle = [[NSMutableParagraphStyle alloc]init];
paragraphStyle.lineBreakMode = NSLineBreakByWordWrapping;
NSDictionary *attributes = @{NSFontAttributeName:[UIFont systemFontOfSize:14], NSParagraphStyleAttributeName:paragraphStyle};
CGSize labelSize = [strTest boundingRectWithSize:CGSizeMake(207, MAXFLOAT) options:NSStringDrawingUsesLineFragmentOrigin attributes:attributes context:nil].size;
NSLog(@"---------%f",labelSize.height);

这些可应用到uitableviewCell的高度自适应上,假如自定义cell上有label的话。

 

2.计算UILabel内实际行数

UILabel虽然可以通过numberOfLines = 0属性来设置不限制行数,但有多行时,需要知道字体的实际行数,则可以用:

UILabel *myLabel = [[UILabel alloc] init];
myLabel.frame = CGRectMake(14, 5, 214, 0.5);
NSString *strTest = @"这是一段测试数据";
CGSize maxSize = CGSizeMake(ScreenWidth-175, MAXFLOAT);
UIFont *font = [UIFont systemFontOfSize:14];
CGSize size =  [strTest sizeWithFont:font constrainedToSize:maxSize lineBreakMode:NSLineBreakByWordWrapping];
//size.height为字符串实际所占高度
CGFloat labelNum = size.height/myLabel.font.lineHeight;

labelNum即为实际行数

IOS中获取label中文本的高度及tableviewCell的自适应

标签:

原文地址:http://www.cnblogs.com/Apologize/p/4844822.html

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