UITextView自适应高度

本文详细讲解了如何在iOS应用中实现UITextView的内容自适应高度,包括监听文字变化、计算新高度和更新约束等关键步骤,旨在帮助开发者优化用户输入体验。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

currentLineNum = 1;//默认文本框显示一行文字
NSDictionary *dict=@{NSFontAttributeName:[UIFont systemFontOfSize:14.0]};
CGSize contentSize=[@"我" sizeWithAttributes:dict];
heightText = contentSize.height;

self.textView.font = [UIFont systemFontOfSize:14.0];
self.textView.textContainerInset = UIEdgeInsetsZero;
self.textView.textContainer.lineFragmentPadding = 0;
self.textView.delegate = self;

#pragma mark - UITextViewDelegate
- (void)textViewDidChange:(UITextView *)textView{
    float textViewWidth = self.textView.frame.size.width;//取得文本框高度
    NSString *content = textView.text;
    NSDictionary *dict = @{NSFontAttributeName:[UIFont systemFontOfSize:14.0]};
    CGSize contentSize = [content sizeWithAttributes:dict];//计算文字长度
    float numLine = ceilf(contentSize.width/textViewWidth);
    if(numLine > currentLineNum ){
        //如果发现当前文字长度对应的行数超过。 文本框高度,则先调整当前view的高度和位置,然后调整输入框的高度,最后修改currentLineNum的值
        self.layoutViewTextHeight.constant = self.textView.frame.size.height+heightText*(numLine-currentLineNum) + 28.0;
        currentLineNum = numLine;

   }else if (numLine < currentLineNum ){
       //次数为删除的时候检测文字行数减少的时候
       if (numLine <= 1) {
           self.layoutViewTextHeight.constant = 48.0;
       }else {
           self.layoutViewTextHeight.constant = self.textView.frame.size.height-heightText*(currentLineNum-numLine) + 28.0;
       }
    }
    
    if (numLine == 0) {
        numLine = 1;
    }
    currentLineNum = numLine;
}

- (void)scrollViewDidScroll:(UIScrollView*)scrollView {
    // 防止换行时抖动
    scrollView.contentOffset = CGPointZero;
}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值