iOS中的长文本高度计算-阿里云开发者社区

开发者社区> 开发与运维> 正文

iOS中的长文本高度计算

简介:

很多的时候如果只是要显示一些简单的短文本,比如确定、取消什么的,一个UILabel就足够了。

 

但是某些情况下,文本较长。包含这些文本的View的高度取决于文本的高度。比如我们常见的

微博。虽然文本所占的高度内容限制在了140字,但是用户发的微博是140字内的多少字,

我们不清楚。那么在用到UITableView的时候,每条微博所在的Cell的高度都要根据其中包含的

文字及其他内容所需要的实际高度来进行设定。当然,此文只讨论文本的高度计算问题,而且

难度也只集中在文本的动态高度上。 

 

长文本高度的计算没有方便的方法,虽然简单。在计算前必须要给出长文本所在view的宽度

 和一个无限高度,然后计算长文本实际使用的高度。由以上条件可以得出一个计算公式:

         实际高度 = f(text, view.width, 9999);

但是还有一个因素不能忘记:字体(font )。用9999代表无限高度这个不用解释了吧:

目前来说iPhone的显示高度还没有9999这么多。 但是这里的无限高度可以看做是一个常数。所以

从参数中去掉。最后的公式是:

            实际高度 = f(text, font, view.width);

很幸运,上面公式里的f,也就是映射关系非常简单。从下面的一个例子可见端倪。 

复制代码
1 - (CGFloat) calculateTextHeight:(UIFont *)font givenText:(NSString *)text givenWidth:(NSUinteger)width{
2  
3      CGSize size = [text sizeWithFont:font constrainedToSize:CGSizeMake(width, 9999)
4                                                lineBreakMode:UILineBreakModeWordWrap];
5      CGFloat delta = size.height;
6  
7      return delta;
8 }
复制代码

 

 

最后你可以用计算出来的不同长度文本的高度来设置包含这段文本的View的高度。如下所示:

 

复制代码
 1  - (void) resizeLabel:(UILabel *)theLabel shrinkViewIfLabelShrinks:(BOOL)canShrink {
 2     CGRect frame = [theLabel frame];
 3     CGSize size = [self calculateTextHeight:theLabel.font givenText:theLabel.text givenWidth:frame.size.width];
 4 
 5     CGFloat delta = size.height - frame.size.height;
 6     frame.size.height = size.height;
 7     [theLabel setFrame:frame];
 8  
 9     CGRect contentFrame = self.frame;
10     contentFrame.size.height = contentFrame.size.height + delta;
11     if(canShrink || delta > 0) {
12         [self setFrame:contentFrame];
13 }
复制代码

 

全文完。如果对你有帮助,请点推荐。谢谢!

 

 

 

 

 

 

欢迎加群互相学习,共同进步。QQ群:iOS: 58099570 | Android: 330987132 | Go:217696290 | Python:336880185 | 做人要厚道,转载请注明出处!http://www.cnblogs.com/sunshine-anycall/archive/2012/07/31/2617385.html

版权声明:本文内容由阿里云实名注册用户自发贡献,版权归原作者所有,阿里云开发者社区不拥有其著作权,亦不承担相应法律责任。具体规则请查看《阿里云开发者社区用户服务协议》和《阿里云开发者社区知识产权保护指引》。如果您发现本社区中有涉嫌抄袭的内容,填写侵权投诉表单进行举报,一经查实,本社区将立刻删除涉嫌侵权内容。

分享:
开发与运维
使用钉钉扫一扫加入圈子
+ 订阅

集结各类场景实战经验,助你开发运维畅行无忧

其他文章