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