[转]IOS动态获取文本的高度--自适应文本宽度、高度Textview
转载整理. 转载参考 见 博文底部
最新遇到一个问题,需要显示一个可变长度的文本文字。
通常我们会先计算这部分文字需要显示出来的高度值,然后把这个高度值设置成UITextView的高度值。这样就做到了自动适配显示。
- 之前我们是采用网上说的那种方式
<pre><code>
-
(float) heightForTextView: (UITextView *)textView WithText: (NSString *) strText{
float fPadding = 16.0; // 8.0px x 2CGSize constraint = CGSizeMake(textView.contentSize.width - fPadding, CGFLOAT_MAX);
CGSize size = [strText sizeWithFont: textView.font constrainedToSize:constraint lineBreakMode:UILineBreakModeWordWrap];
float fHeight = size.height + 16.0;
return fHeight;
}
</code></pre>
可是 sizeWithFont 在7.0 被废弃了 替代的方法是:<pre>CGSize size = [@"10" sizeWithAttributes: @{NSFontAttributeName: [UIFont fontWithName:self.myFont size:10]}];</pre>
结果发现在ios6上计算出的长度根本不对, 会致使有一部分文字显示不出来的情况。但在ios7上上面这部分代码是正确的。注:ios6, ios7对同样的文字内容,即使使用的是相同的文字大小,计算出来的高度也是不一样的。
注:今天发现, 上面这个方法在真机上是正常的,在XCode 5的模拟器上ios6上会有问题。 这应该是XCode 5的ios6模拟器的一个bug, 供各位参考
- 后来自己再尝试了一番, 终于找到一个好的办法来解决这个问题。(个人觉得下面这种方法比较赞,下面这种方法不需要考虑上面方法中的 UITextView的 8 padding问题,相对比较容易理解)
<pre><code>
+ (float) heightForString:(NSString *)value fontSize:(float)fontSize andWidth:(float)width
{
UITextView *detailTextView = [[UITextView alloc]initWithFrame:CGRectMake(0, 0, width, 0)];
detailTextView.font = [UIFont systemFontOfSize:fontSize];
detailTextView.text = value;
CGSize deSize = [detailTextView sizeThatFits:CGSizeMake(width,CGFLOAT_MAX)];
return deSize.height;
}
<code></pre>
自己测试使用过, ios6, ios7上均能计算出正常的值, 虽然同样的内容,同样的文字大小,计算出来的高度还是不一样。
- 在网上查了一下, 有的说是用UILabel试一下, 配合CGSize size = [strText sizeWithFont: textView.font constrainedToSize:constraint lineBreakMode:UILineBreakModeWordWrap]; 这种方式也可以得正常的显示值, (注意:在使用UILabel来时,计算文字高度时, 不需要像上面第一部分代码中搞一个8 padding)
经验证:
sizeWithFont这个方法貌似确实是针对UILabel的,如果用UILabel来显示,其计算出来的高度和实际高度是吻合的。但是需要注意的是UILabel的文字内容和UILabel的宽度几乎是重合的,这会让人觉得文字太过于帖边了,可以考虑设置其contentInset之类来处理,不过这个是另一个问题了。而UITextView则不会太帖边,且行间距较大,适合显示。 估计UILabel应该也可以设置其行间距和段间距的。
参考博文: