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

【转】UILabel、UITextView自适应得到高度

时间:2015-09-18 13:24:52      阅读:117      评论:0      收藏:0      [点我收藏+]

标签:

原文:http://blog.csdn.net/xcysuccess3/article/details/8331549

在iOS中,经常遇到需要根据字符串的内容动态指定UILabel,UITextView,UITableViewCell等的高度的情况,这个时候就需要动态的计算字符串内容的高度,下面是计算的方法:

 

[cpp] view plaincopy
 
  1. /**  
  2.  @method 获取指定宽度情况ixa,字符串value的高度 
  3.  @param value 待计算的字符串 
  4.  @param fontSize 字体的大小 
  5.  @param andWidth 限制字符串显示区域的宽度 
  6.  @result float 返回的高度 
  7.  */ floatfloatfloat   
  8. return  




前不久QA报了个文字显示不全的bug,我看了下代码,发现是计算高度出了问题。之前的同事在UITableViewCell中使用了UITextView,但是计算高度时使用了和UILabel相同的的方法。

 
其实UITextView在上下左右分别有一个8px的padding,当使用[NSString sizeWithFont:constrainedToSize:lineBreakMode:]时,需要将 UITextView.contentSize.width减去16像素(左右的padding 2 x 8px)。同时返回的高度中再加上16像素(上下的padding),这样得到的才是UITextView真正适应内容的高度。
 
示例代码如下:
  1. + (float) heightForTextView: (UITextView *)textView WithText: (NSString *) strText{  
  2.     float fPadding = 16.0; // 8.0px x 2  
  3.     CGSize constraint = CGSizeMake(textView.contentSize.width - fPadding, CGFLOAT_MAX);  
  4.    
  5.     CGSize size = [strText sizeWithFont: textView.font constrainedToSize:constraint lineBreakMode:UILineBreakModeWordWrap];  
  6.    
  7.     float fHeight = size.height + 16.0;  
  8.    
  9.     return fHeight;  
  10. }  


【转】UILabel、UITextView自适应得到高度

标签:

原文地址:http://www.cnblogs.com/A--G/p/4818726.html

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