【轉】UILabel、UITextView自適應獲得高度

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

在iOS中,常常遇到須要根據字符串的內容動態指定UILabel,UITextView,UITableViewCell等的高度的狀況,這個時候就須要動態的計算字符串內容的高度,下面是計算的方法:ide

 

[cpp]  view plain copy
 
  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真正適應內容的高度。
 
示例代碼以下:
[html] view plain copy
  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.  / / 注意:計算textview 高度 //textview 的font 不能爲空
  5.     CGSize size = [strText sizeWithFont: textView.font constrainedToSize:constraint lineBreakMode:UILineBreakModeWordWrap];  
  6.    
  7.     float fHeight = size.height + 16.0;  
  8.    
  9.     return fHeight;  
  10. }  
相關文章
相關標籤/搜索