//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. Gym - 101164C - Castle KMP

    题目链接:传送门 题解: 利用KMP的fail失配数组,快速找到当前后缀与前缀的公共前缀点 #include<bits/stdc++.h> using namespace std; #pr ...

  2. Hadoop_stack_cmd

    HDFS命令基本格式:Hadoop fs -cmd < args > HDFS命令基本格式:Hadoop fs -cmd < args > ls 命令 hadoop fs -l ...

  3. idea 破解注册方法总结

    注册码(无期限) JetbrainsCrack-2.6.2.jar适用于ideaIU-2017.2.之前版本,若版本较新适用 JetbrainsCrack-2.6.3_proc.jar. 其中Jetb ...

  4. 获取浏览器屏幕高度(js,jq)

    javascript IE中:document.body.clientWidth ==> BODY对象宽度document.body.clientHeight ==> BODY对象高度do ...

  5. WinDbg设置托管进程断点

    WinDbg的Live模式调试..Net 托管代码 ,使用bp,bu,bm无法设置断点,也许是我不会.研究了下,托管代码有自己的命令,!BPMD 模块名 完全限定的方法名 步骤: 1.查找进程PID, ...

  6. 关于苹果iPhone手机对页面margin属性无效的解决方法一(如有错误,请留言批评)

    这个问题,是在给商城网站底部footer设置margin属性的时候发现的,先把出现问题的截图发出来看一下 ​安卓手机,打开正常 ​iphone6 p 打开出现的问题(无视margin-bottom:6 ...

  7. HDU - 1874 畅通工程续(最短路径)

    d.已知起点和终点,请你计算出要从起点到终点,最短需要行走多少距离. s.最短路径 c.Dijkstra单源最短路 /* Dijkstra单源最短路 权值必须是非负 单源最短路径,Dijkstra算法 ...

  8. CollectionView垂直缩放卡片布局

    实现效果 实现思路 从效果图可以看到变化是,越是往中间滚动的item显示最大,越显眼.而越是往前面,或者越是后面的,反而显示越小,这样就形成了视觉差. 实现的思路就是通过重写在可见范围内的所有item ...

  9. [AHOI 2005] 航线规划

    [题目链接] https://www.lydsy.com/JudgeOnline/problem.php?id=1969 [算法] 首先离线 , 将删边操作转化为加边操作 不妨首先将这张图按边-双连通 ...

  10. 【前端】Nodejs给没有引号的json数据添加引号

    转载请注明出处:http://www.cnblogs.com/shamoyuu/p/node_json.html 我们经常会遇到一些json数据需要放到json文件中,然后动态加载的场景. 但是也经常 ...