zoukankan      html  css  js  c++  java
  • UITextView高度随文字自动增加

      float heightText;//文字高度

    NSDictionary *dict=@{NSFontAttributeName:[UIFont systemFontOfSize:20.0]};  

    CGSize contentSize=[@"我" sizeWithAttributes:dict];  

    heightText=contentSize.height; 

     

    实现 UITextViewDelegate 协议的 

    -(void)textViewDidChange:(UITextView *)textView  

    {  

      float currentLineNum=1;//默认文本框显示一行文字  

      float textViewWidth=self.textView.frame.size.width;//取得文本框高度

       NSString *content=textView.text;  

      NSDictionary *dict=@{NSFontAttributeName:[UIFont systemFontOfSize:20.0]};  

        CGSize contentSize=[content sizeWithAttributes:dict];//计算文字长度  

      float numLine=ceilf(contentSize.width/textViewWidth); //计算当前文字长度对应的行数    if(numLine>currentLineNum )

    {  //如果发现当前文字长度对应的行数超过。 文本框高度,则先调整当前view的高度和位置,然后调整输入框的高度,最后修改currentLineNum的值  

      self.frame=CGRectMake(self.frame.origin.x, self.frame.origin.y-heightText*(numLine-currentLineNum);

      self.frame.size.width, self.frame.size.height+heightText*(numLine-currentLineNum));  

            textView.frame=CGRectMake(textView.frame.origin.x, textView.frame.origin.y, textView.frame.size.width, textView.frame.size.height+heightText*(numLine-currentLineNum));  

            currentLineNum=numLine; 

       }else if (numLine<currentLineNum ){

     //次数为删除的时候检测文字行数减少的时候  

      self.frame=CGRectMake(self.frame.origin.x, self.frame.origin.y+heightText*(currentLineNum-numLine);

      self.frame.size.width, self.frame.size.height-heightText*(currentLineNum-numLine));  

            textView.frame=CGRectMake(textView.frame.origin.x, textView.frame.origin.y, textView.frame.size.width, textView.frame.size.height-heightText*(currentLineNum-numLine));  

            currentLineNum=numLine;  

        }  

    }  

  • 相关阅读:
    vue异步组件
    vue-awesome-swiper的使用
    自定义button组件时slot的使用
    axios拦截器的简单使用
    vue静态类名和动态类名绑定的几种方式
    快速知道所有元素的边框
    【转】CICD工具
    mocha学习(四)为项目开发一个BDD测试
    mocha学习(三)hook 机制 和 测试技巧
    mocha学习(二)mocha接口
  • 原文地址:https://www.cnblogs.com/lhx2015/p/4736816.html
Copyright © 2011-2022 走看看