很多的时候如果只是要显示一些简单的短文本,比如确定、取消什么的,一个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 }
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 }
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: 572064792 | Nodejs:329118122 做人要厚道,转载请注明出处!
本文转自张昺华-sky博客园博客,原文链接:http://www.cnblogs.com/sunshine-anycall/archive/2012/07/31/2617385.html
,如需转载请自行联系原作者