IOS UITextView自适应高度
LOFTER app需要實現了一個類似iPhone短信輸入框的功能,它的功能其實蠻簡單,就是:【UITextView的高度隨著內容高度的變化而變化】。實現思路應該是:
在UITextView的textChanged事件響應代碼里計算輸入內容的高度,然后如果高度與文本變化前比起來有變化,則修改UITextView的高度為這個新的高度。
這看起來很簡單。
添加內容變化的通知響應事件:
[[NSNotificationCenter defaultCenter] addObserver:self selector:@selector(textChanged:) name: UITextViewTextDidChangeNotification object:nil];
計算內容高度有兩種方式:
CGSize newSize = [textView.text
? ? ? ? ? ? sizeWithFont:[UIFont fontWithName:@"Helvetica" size:14]
? ? ? ? ? ? constrainedToSize:CGSizeMake(222,9999)
? ? ? ? ? ? lineBreakMode:UILineBreakModeWordWrap];
? ? 2. ?textView繼承自UIScrollView,直接從contentSize屬性獲取
textView.contentSize.height
第一種方式拿出來的高度需要再加上padding的值才是最終的值(即每行的空白區域),并且需要指定constrainedToSize,不太靈活。第二種方法簡單直接準確,我選擇了它。
在IOS 5.0及以上,以上實現已經足夠完美了。在IOS4.3中發現了bug,當文本框變成多行,然后清空文本框再輸入文字時,發現內容和光標跑到了UITextView上方并且不可見。Google關鍵字"one line uitextview"可以發現類似的bug提問。經過查證資料和跟蹤代碼,根本原因應該UITextView的Insets.bottom在文本輸入的過程中被不斷地自動設置造成的。這是UITextView的默認實現行為,但這肯定是IOS4.3的bug,而IOS5.0修復了它。解決辦法就是試圖阻止UITextView設置contentInset,我們可以繼承UITextView并且覆蓋setContentInset:方法來達到目的,在setContentInset:里只需要設置一個固定的contentInset.bottom即可。
還有一個地方需要注意,當你清空輸入框時(_textView.text=@"";),不會自動觸發textChanged:,你需要重寫setText:方法來調用textChanged:。并且你清空textview后,你拿到的contentsize也不準確,所以還需要根據text是否為空來設定一個最小的高度。
在iOS 7以前,如果要實現UITextView自適應高度的話,可通過取contentSize.height的方法來設置。但在iOS 7上這種方法是無效的,下面是一種簡單的處理方法:
- (CGSize)contentSizeOfTextView:(UITextView *)textView
{
? ? CGSize textViewSize = [textView sizeThatFits:CGSizeMake(textView.frame.size.width, FLT_MAX)];
? ? return textViewSize;
}
轉載于:https://www.cnblogs.com/melons/p/5792021.html
總結
以上是生活随笔為你收集整理的IOS UITextView自适应高度的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 计算 KL距离 (相对熵)
- 下一篇: Css 选择器 算法 规则