//UILabel自适应文本的高度

    UILabel *label = [[UILabel alloc]initWithFrame:CGRectMake(, , , )];

    label.numberOfLines = ;

    label.lineBreakMode = NSLineBreakByWordWrapping;

    label.text = @"是它吗?哈哈,太兴奋了。”12日,随着土豪金版100元人民币正式发行,到了中午,不少长春市民也陆续在其朋友圈晒出了他们拿到的新版人民币。不过,先别高兴,不少验钞机还没升级,可能误认它是假钞。";

    CGSize size = [label sizeThatFits:CGSizeMake(label.frame.size.width, MAXFLOAT)];

    label.frame =CGRectMake(, , , size.height);

    label.font = [UIFont systemFontOfSize:];

    [self.view addSubview:label];

以下方法可以做到在固定label大小里面根据文本多少来确定字体的大小。

//让文本自适应Label

    //经常遇到,UILabel里面的显示区域固定,   但是里面的文字显示合适的字体大小的时候,可以用下面的方法:

    UILabel *label = [[UILabel alloc]initWithFrame:CGRectMake(, , , )];

    label.backgroundColor = [UIColor clearColor];

    label.textColor = [UIColor redColor];

    label.font = [UIFont systemFontOfSize:];

    label.adjustsFontSizeToFitWidth = YES;

    label.minimumFontSize = ;//默认为0

    label.text = @"flying in the sky";

    //就是在空间够的情况下,使用20号字体,如果空间不够,那么就会自动将字体向下调整,但是也不会少于6号字体,如果6号字体也显示不完,后续显示省略号。。。

    [self.view addSubview:label];

另外一些自适应文本高度的方法:

//自适应label高度,方法一:
UILabel *label = [[UILabel alloc]initWithFrame:CGRectMake(, , , )];
NSString *text = @"First take clear picture and then try to zoom in to fit the ";
label.text = text;
label.lineBreakMode = UILineBreakModeWordWrap; //这个是关键
label.numberOfLines = ; //这个是关键
 CGSize maximumSize = CGSizeMake(, CGFLOAT_MAX); // 第一个参数是label的宽度,第二个参数是固定的宏定义,CGFLOAT_MAX
CGSize expectedLabelSize = [text sizeWithFont:label.font
constrainedToSize:maximumSize
lineBreakMode:UILineBreakModeWordWrap]; CGRect newFrame = label.frame;
newFrame.size.height = expectedLabelSize.height;
label.frame = newFrame;
[label sizeToFit];
[self addSubview:label];

综合主要代码:

UILabel *label=[[UILabel alloc]initWithFrame:CGRectMake(10, 225, 300, 180)];
NSString *string = @"First take clear picture and then try to zoom in to fit the "; 
CGRect orgRect=self.label.frame;//获取原始UILabel的frame
[label  setNumberOfLines:0];   //numberoflines为0,即不做行数的限制  
CGSize size = [string sizeWithFont:[UIFont systemFontOfSize:] constrainedToSize:CGSizeMake(, )lineBreakMode:UILineBreakModeWordWrap]; 
orgRect.size.height=size.height+;  //获取自适应文本内容高度
[label setFrame: orgRect];   //重设UILabel的frame
[label setText: string];

UITextView的设置与Label差不多

NSString *string="是它吗?哈哈,太兴奋了。”12日,随着土豪金版100元人民币正式发行,到了中午,不少长春市民也陆续在其朋友圈晒出了他们拿到的新版人民币。不过,先别高兴,不少验钞机还没升级,可能误认它是假钞。";//获取文本内容  

CGRect orgRect=self.txtView.frame;//获取原始UITextView的frame  

CGSize  size = [string sizeWithFont:[UIFont systemFontOfSize:] constrainedToSize:CGSizeMake(, ) lineBreakMode:UILineBreakModeWordWrap];    

orgRect.size.height=size.height+;//获取自适应文本内容高度  

    self.txtView.frame=orgRect;//重设UITextView的frame  

self.txtView.text=string;  

iOS UILabel UITextView自适应文本,或文本大小自适应的更多相关文章

  1. iOS UILabel UITextView UIButton 等等显示文本行间距

    iOS UILabel  UITextView UIButton 等等显示文本行间距都用如下方法 NSMutableParagraphStyle *paragraphStyle = [[NSMutab ...

  2. iOS - UILabel添加图片之富文本的简单应用

    //创建富文本 NSMutableAttributedString *attri = [[NSMutableAttributedString alloc] initWithString:@" ...

  3. 【iOS】WebView加载HTML图片大小自适应与文章自动换行

    在很多App中都会使用到webview,尤其是在加载新闻内容等文章形式的数据时.因为图文混编以及不同字体格式的显示,在iOS进行编辑 和显示都是一大问题(当然,iOS中也可以用CoreText进行绘制 ...

  4. WebView加载HTML图片大小自适应与文章自动换行

    http://www.brighttj.com/ios/ios-webview-load-html-image-adaptive.html 在很多App中都会使用到webview,尤其是在加载新闻内容 ...

  5. IOS 学习笔记(5) 控件 文本视图(UITextView)的使用方法

    相对于UILabell所支持的较短文本内容,UITextView对于长文本的支持更好.UITextView能够以滚动的方式全部浏览到长文本,并且就像UILabel那样,从ISO6,他也提供了对NSAt ...

  6. Xamarin iOS教程之显示和编辑文本

    Xamarin iOS教程之显示和编辑文本 Xamarin iOS显示和编辑文本 在一个应用程序中,文字是非常重要的.它就是这些不会说话的设备的嘴巴.通过这些文字,可以很清楚的指定这些应用程序要表达的 ...

  7. iOS 9应用开发教程之多行读写文本ios9文本视图

    iOS 9应用开发教程之多行读写文本ios9文本视图 多行读写文本——ios9文本视图 文本视图也是输入控件,与文本框不同的是,文本视图可以让用户输入多行,如图2.23所示.在此图中字符串“说点什么吧 ...

  8. 使用contenteditable+div模拟textarea文本域实现高度自适应

    使用contenteditable+div模拟textarea文本域实现高度自适应 开发过程中由于需要在发送消息的时候需要有一个可以高度自适应的文本域,一开始是使用textarea并搭配auto-si ...

  9. 我的插件のinput文本框实现宽度自适应

    先来最后结果:DEMO 介绍一下如何让一个文本框的宽度能够随着文本框中的内容的宽度增长而增长,也就是能够实现宽度自适应效果. 代码实例如下: <!DOCTYPE html> <htm ...

随机推荐

  1. sanic官方文档解析之streaming(流动,滚动)和class_based_views(CBV的写法)

    1,streaming(流媒体) 1.1请求流媒体 Sanic允许你通过流媒体携带请求数据,如下,当请求结束await request.stream.read()就会返回None,仅仅只有post请求 ...

  2. UI类继承关系图

  3. https://bitbucket.org/ariya/phantomjs/downloads/phantomjs-2.1.1-linux-x86_64.tar.bz2

    https://bitbucket.org/ariya/phantomjs/downloads/phantomjs-2.1.1-linux-x86_64.tar.bz2

  4. 微信的API都是通过https调用实现的,分为post方法调用和get方法调用。不需要上传数据的采用get方法(使用IntraWeb开发)

    首先需要明确的是,微信的API都是通过https调用实现的,分为post方法调用和get方法调用.不需要上传数据的采用get方法(例如获取AccessToken),而需要向微信服务器提交数据的采用po ...

  5. spring boot---WebFilter注解 实现自定义登录过滤器

    https://my.oschina.net/wangnian/blog/647976 http://www.jianshu.com/p/05c8be17c80a

  6. vue 使用html2canvas将DOM转化为图片

    一.前言 我发现将DOM转化为图片是一个非常常见的需求,而自己手动转是非常麻烦的,于是找到了html2canvas这个插件,既是用得比较多的也是维护得比较好的一个插件. 注意:版本比较多,这里介绍最新 ...

  7. [RK3399][Android7.1] 调试笔记 --- 模块编译32位动态库【转】

    本文转载自:http://blog.csdn.net/kris_fei/article/details/78923784 Platform: RK3399 OS: Android 7.1 Board: ...

  8. POJ1077 Eight —— A*算法

    主页面:http://www.cnblogs.com/DOLFAMINGO/p/7538588.html 关于A*算法:g(n)表示从起点到任意节点n的路径花费,h(n)表示从节点n到目标节点路径花费 ...

  9. 使用JQuery.Validate插件来校验页面表单有效性

    使用JQuery.Validate插件来校验页面表单有效性​1. [代码] 常见的注册表单元素 <form action="#" method="post" ...

  10. java 连接飞信API

    通过java连接飞信api给自己的好友(包括自己)发送飞信内容.如果对方的手机号非你的飞信好友则不能发送.​​1. [代码]飞信发送类     package per.artisan.fetion; ...