iOS自動計(jì)算高度的UITextView

自定義TextView與其他人的不同點(diǎn)

在做自定義textView時(shí)独旷,我發(fā)現(xiàn)很多人是使用boundingRectWithSize來計(jì)算textView的text的高度逝薪,從而更新textView的高度丢郊。其實(shí)這種做法是多余的曼月。UITextView本身就是繼承自UIScrollView的容达,所以UITextView本身是有一個(gè)contentSize的屬性的。每當(dāng)UITextView的高度發(fā)生變化冰沙,UITextView的contentSize屬性的height就會發(fā)生變化侨艾,所以我根據(jù)這一點(diǎn),使用KVO監(jiān)聽contentSize屬性即可獲得textView的最新高度拓挥。本文自定義的textView使用場景:UITableViewCell里自動計(jì)算行高的textView唠梨。

主要代碼:

// KVO
- (void)observeValueForKeyPath:(NSString *)keyPath ofObject:(id)object change:(NSDictionary<NSKeyValueChangeKey,id> *)change context:(void *)context {
    if ([keyPath isEqualToString:@"contentSize"]) {
        [self configureTextViewFrame];
    }
}

// 計(jì)算textView的frame
- (void)configureTextViewFrame {
    // self的frame是初始化時(shí)定的,默認(rèn)是父視圖的高度
    // 只有當(dāng)contentSize的高度小于self的高度時(shí)才需要計(jì)算高度侥啤,超出則不計(jì)算
    if (self.textView.contentSize.height < self.bounds.size.height) {
        CGRect rect = self.bounds;
        // textView擴(kuò)展方向:向兩邊(默認(rèn))当叭;向下;向上
        switch (self.extendDirection) {
            case YSTextViewExtendDirectionBothsides:
                rect.origin.y = (rect.size.height - self.textView.contentSize.height) / 2.f;
                break;
            case YSTextViewExtendDirectionUpside:
                rect.origin.y = rect.size.height - self.textView.contentSize.height;
                break;
            case YSTextViewExtendDirectionDownside:
                rect.origin.y = 0;
                break;
        }
        rect.size.height = self.textView.contentSize.height;
        self.textView.frame = rect;
    } else {
        self.textView.frame = self.bounds;
        self.isExtending = NO;
    }
    CGRect textBounds = self.textView.bounds;
    textBounds.origin.x += 5.f;
    self.placeholderLabel.frame = textBounds;
}

調(diào)用示例:

// contentView模擬UITableViewCell的contentView
UIView *contentView = [[UIView alloc] initWithFrame:CGRectMake(100, 200, 200, 100)];
    [self.view addSubview:contentView];
    contentView.backgroundColor = [UIColor lightGrayColor];

    YSExtendTextView *textView = [YSExtendTextView new];
    textView.frame = CGRectMake(15, 5, 170, 90);
    textView.extendDirection = YSTextViewExtendDirectionDownside;// 輸入框延伸方向(默認(rèn)是從中間向兩邊)
    textView.placeholder = @"請輸入文字~";
    [contentView addSubview:textView];

喜歡該控件的朋友可以從github下載使用盖灸。
GitHub

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末蚁鳖,一起剝皮案震驚了整個(gè)濱河市,隨后出現(xiàn)的幾起案子赁炎,更是在濱河造成了極大的恐慌醉箕,老刑警劉巖,帶你破解...
    沈念sama閱讀 218,036評論 6 506
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件甘邀,死亡現(xiàn)場離奇詭異琅攘,居然都是意外死亡,警方通過查閱死者的電腦和手機(jī)松邪,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 93,046評論 3 395
  • 文/潘曉璐 我一進(jìn)店門坞琴,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人逗抑,你說我怎么就攤上這事剧辐。” “怎么了邮府?”我有些...
    開封第一講書人閱讀 164,411評論 0 354
  • 文/不壞的土叔 我叫張陵荧关,是天一觀的道長。 經(jīng)常有香客問我褂傀,道長忍啤,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 58,622評論 1 293
  • 正文 為了忘掉前任仙辟,我火速辦了婚禮同波,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘叠国。我一直安慰自己未檩,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,661評論 6 392
  • 文/花漫 我一把揭開白布粟焊。 她就那樣靜靜地躺著冤狡,像睡著了一般孙蒙。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上悲雳,一...
    開封第一講書人閱讀 51,521評論 1 304
  • 那天挎峦,我揣著相機(jī)與錄音,去河邊找鬼怜奖。 笑死浑测,一個(gè)胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的歪玲。 我是一名探鬼主播,決...
    沈念sama閱讀 40,288評論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼掷匠,長吁一口氣:“原來是場噩夢啊……” “哼滥崩!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起讹语,我...
    開封第一講書人閱讀 39,200評論 0 276
  • 序言:老撾萬榮一對情侶失蹤钙皮,失蹤者是張志新(化名)和其女友劉穎,沒想到半個(gè)月后顽决,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體短条,經(jīng)...
    沈念sama閱讀 45,644評論 1 314
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,837評論 3 336
  • 正文 我和宋清朗相戀三年才菠,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了茸时。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點(diǎn)故事閱讀 39,953評論 1 348
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡赋访,死狀恐怖可都,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情蚓耽,我是刑警寧澤渠牲,帶...
    沈念sama閱讀 35,673評論 5 346
  • 正文 年R本政府宣布,位于F島的核電站步悠,受9級特大地震影響签杈,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜鼎兽,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,281評論 3 329
  • 文/蒙蒙 一答姥、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧接奈,春花似錦踢涌、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,889評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至,卻和暖如春潘明,著一層夾襖步出監(jiān)牢的瞬間行剂,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 33,011評論 1 269
  • 我被黑心中介騙來泰國打工钳降, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留厚宰,地道東北人。 一個(gè)月前我還...
    沈念sama閱讀 48,119評論 3 370
  • 正文 我出身青樓遂填,卻偏偏與公主長得像铲觉,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個(gè)殘疾皇子吓坚,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 44,901評論 2 355

推薦閱讀更多精彩內(nèi)容