如何解决boundingRectWithSize:存在多个换行符时,UILabel高度的计算不正确
我正在尝试以编程方式计算标签的高度。
在我的案例中,示例文本如下:
Lorem ipsum dolor坐下来,奉献己任,sius do eiusmod tempor incididunt ut labour et dolore magna aliqua。
要尽量减少抽烟,不要因抽烟而锻炼。 Duis aute irure dolor in reprehenderit in voltate velit esse cillum dolore eu fugiat nulla pariatur。
非故意的圣人八卦数据,在犯罪现场的罪魁祸首。
我用来计算标签高度的代码:
-(CGFloat)getLabelHeightUsingWidth:(CGFloat)cellWidth
{
NSInteger fontSize = 16;
UIFont *descLabelFont = [UIFont fontWithName:@"MyFontName" size:fontSize];
NSString *description = <sample text provided above>;
CGSize constraint = CGSizeMake(width,CGFLOAT_MAX);
CGSize size;
NSStringDrawingContext *context = [[NSStringDrawingContext alloc] init];
CGSize boundingBox = [text boundingRectWithSize:constraint options:NSStringDrawingUsesLineFragmentOrigin attributes:@{NSFontAttributeName:font}
context:context].size;
size = CGSizeMake(ceil(boundingBox.width),ceil(boundingBox.height));
return size.height ;
}
对于其中包含单行或不包含换行符的文本内容,它会给出适当的高度,但不会像我的示例文本中那样带有doublenewline。如果存在双换行符,则返回的计算高度小于实际需要的高度。因此,返回的高度会更少,而显示时的原始高度会更多,这会给我在其中显示多行字符串的表格单元格造成不正确的高度问题。
因此,我推断双换行符可能是问题,并尝试使用单个换行符删除双换行符。然后,计算出的高度是正确的。
处理这种情况的正确方法是什么?
解决方法
很难确切地说出问题所在……也许(偶然地)您没有使用相同的字体?也许(偶然)没有使用完全相同的字符串?
无论如何,这似乎有点奇怪。
尝试一下:
LabelHeightViewController.h
#import <UIKit/UIKit.h>
NS_ASSUME_NONNULL_BEGIN
@interface LabelHeightViewController : UIViewController
@end
NS_ASSUME_NONNULL_END
LabelHeightViewController.m
#import "LabelHeightViewController.h"
@interface LabelHeightViewController ()
@property (strong,nonatomic) UILabel *myLabel;
@property (strong,nonatomic) UIView *redView;
@end
@implementation LabelHeightViewController
- (void)viewDidLoad {
[super viewDidLoad];
_myLabel = [UILabel new];
_redView = [UIView new];
_myLabel.translatesAutoresizingMaskIntoConstraints = NO;
_redView.translatesAutoresizingMaskIntoConstraints = NO;
_myLabel.numberOfLines = 0;
_myLabel.text = @"Lorem ipsum dolor sit amet,consectetur adipiscing elit,sed do eiusmod tempor incididunt ut labore et dolore magna aliqua.\n\nUt enim ad minim veniam,quis nostrud exercitation ullamco laboris nisi ut aliquip ex ea commodo consequat. Duis aute irure dolor in reprehenderit in voluptate velit esse cillum dolore eu fugiat nulla pariatur.\n\n\nExcepteur sint occaecat cupidatat non proident,sunt in culpa qui officia deserunt mollit anim id est laborum.";
UIFont *font = [UIFont fontWithName:@"Avenir-Book" size:16.0];
_myLabel.font = font;
// we're going to set the label width to 300
CGFloat w = 300.0;
// calculate the height
CGFloat h = [self getLabelHeight:_myLabel forWidth:w];
[self.view addSubview:_myLabel];
[self.view addSubview:_redView];
UILayoutGuide *g = self.view.layoutMarginsGuide;
[NSLayoutConstraint activateConstraints:@[
// constrain label Top: 40 / Leading: 12 / Width: w
[_myLabel.topAnchor constraintEqualToAnchor:g.topAnchor constant:40.0],[_myLabel.leadingAnchor constraintEqualToAnchor:g.leadingAnchor constant:12.0],[_myLabel.widthAnchor constraintEqualToConstant:w],// constrain red view Top: label Top / Leading: label leading + 8
// Width: 20 / Height: h
[_redView.topAnchor constraintEqualToAnchor:_myLabel.topAnchor],[_redView.leadingAnchor constraintEqualToAnchor:_myLabel.trailingAnchor constant:8.0],[_redView.widthAnchor constraintEqualToConstant:20.0],[_redView.heightAnchor constraintEqualToConstant:h],]];
// so we can see the frames
_myLabel.backgroundColor = [UIColor yellowColor];
_redView.backgroundColor = [UIColor redColor];
}
-(CGFloat)getLabelHeight:(UILabel *)theLabel forWidth:(CGFloat)theWidth {
UIFont *descLabelFont = theLabel.font;
NSString *description = theLabel.text;
CGSize constraint = CGSizeMake(theWidth,CGFLOAT_MAX);
NSStringDrawingContext *context = [[NSStringDrawingContext alloc] init];
CGSize boundingBox = [description boundingRectWithSize:constraint
options:NSStringDrawingUsesLineFragmentOrigin
attributes:@{NSFontAttributeName:descLabelFont}
context:context].size;
return ceil(boundingBox.height);
}
@end
结果:
注意:
红色视图的高度设置为返回的高度
-(CGFloat)getLabelHeight:(UILabel *)theLabel forWidth:(CGFloat)theWidth`
文本有两个新行,其中第一个“中断”为\n\n
-第二个中断中有3个换行(\n\n\n
)(用于演示)。
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。