uilabel 自行撑开高度_UILabel文本高度计算的那些事儿

1. 计算文本在一行高度内的宽度

// 段落样式

NSMutableParagraphStyle *paragraphStyle = [[NSMutableParagraphStyle alloc] init];

paragraphStyle.lineSpacing = 6.0;

// 清除掉换行符(或者还要清除空白符,这个看自己需求)

// 要处理掉换行符,否则得不到正确的高度

NSString *intro = [self.columnDict.head.intro copy]; // 这个数据就是文本

intro = [intro stringByReplacingOccurrencesOfString:@"\r" withString:@""];

intro = [intro stringByReplacingOccurrencesOfString:@"\n" withString:@""];

CGRect introRect = [intro boundingRectWithSize:CGSizeMake(CGFLOAT_MAX, 20)

options:0 attributes:@{

NSFontAttributeName:font(14),

NSParagraphStyleAttributeName:paragraphStyle

} context:nil];

CGFloat width = introRect.size.width;

// 如果width是小数,小数部分的宽度不会被渲染,不够一个像素,所以最好向上取整

width = ceil(width);

boundingRectWithSize的第一个参数是CGSize. 一般会设置宽度固定,高度CGFLOAT_MAX来获取在这种显示宽度内的文本高度;或者设置宽度CGFLOAT_MAX,高度固定,来获取某个高度内的文本宽度。比如上边的一行高度内,文本有多长

2. 固定宽度,行数的文本高度(没有设置行间距的情况下)

UILabel *label = [[UILabel alloc] init];

label.numberOfLines = 2;

label.text = self.columnDict.head.intro;

[label sizeToFit];

CGFloat height = label.bounds.size.height;

利用一个UILabel对象,来获取渲染后的文本size,高度。

假设固定行数为2行,如果文本内容比较多,就可以直接用下边的fontLineHeight * 2来设置高度(欢迎高手指正)

3. 固定宽度,行数的文本高度(有设置行间距的情况下)

CGFloat fontLineHeight = _descLabel.font.lineHeight; // 不同系统,字体下高度会和字号大小不同

// 2行,行间距6

CGFloat height = fontLineHeight * 2 + 6;

// 1行,行间距6

CGFloat height = fontLineHeight + 6;

以上两种情况,假设一开始设定高度为2行,但是文本只有一行的时候,那么就直接使用fontLineHeight这个高度来设置Label的高度

4. 固定宽度,纯粹获取文本高度

CGRect introRect = [intro boundingRectWithSize:CGSizeMake(kScreenWidth, CGFLOAT_MAX)

options:0 attributes:@{

NSFontAttributeName:font(14),

NSParagraphStyleAttributeName:paragraphStyle

} context:nil];

CGFloat height = introRect.size.height;

kScreenWidth是一个获取屏幕宽度的宏定义

boundingRectWithSize方法介绍:

size

限制最大宽高, 虽然是自适应, 但是需要限制最大的宽度和高度

options

一个枚举, 绘制自定义方式字符串的选项,可以互相组合。例如:

NSStringDrawingUsesLineFragmentOrigin | NSStringDrawingUsesFontLeading

enum {

NSStringDrawingTruncatesLastVisibleLine = 1 << 5,

NSStringDrawingUsesLineFragmentOrigin = 1 << 0,

NSStringDrawingUsesFontLeading = 1 << 1,

NSStringDrawingUsesDeviceMetrics = 1 << 3,

};typedef NSInteger NSStringDrawingOptions;

NSStringDrawingTruncatesLastVisibleLine :

如果文本内容超出指定的矩形限制,文本将被截去并在最后一个字符后加上省略号 . 如果三选项没有选择, 忽略此选项

NSStringDrawingUsesLineFragmentOrigin :

整个文本将以每行组成的矩形为单位计算整个文本的尺寸

NSStringDrawingUsesFontLeading :

以字体间的行距(leading,行距:从一行文字的底部到另一行文字底部的间距。)来计算高度

NSStringDrawingUsesDeviceMetrics :

计算布局时使用图像符号边界, 而不是排版的边界

attributes

应用于字符串的文本样式字典属性

context

控制如何调整字间距和缩放。对象包含的信息将用于文本绘制。该参数可为 nil

返回值

返回一个矩形CGRect, 这个矩形为文字所占的矩形

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: UILabel 高度自适应是指根据文本内容的多少自动调整UILabel高度,使得文本能够完整显示并且没有截断。在Swift中,可以通过以下几个步骤来实现UILabel高度自适应。 1. 设置UILabel的numberOfLines属性为0,表示文本可以显示多行。 ``` label.numberOfLines = 0 ``` 2. 设置UILabel的preferredMaxLayoutWidth属性为UILabel的宽度,确保文本能够根据UILabel的宽度进行换行。 ``` label.preferredMaxLayoutWidth = label.frame.width ``` 3. 根据文本内容和UILabel的宽度计算出合适的UILabel高度。可以通过UILabel的text属性获取文本内容,再利用boundingRect方法计算文本所占据的空间。 ``` let text = label.text ?? "" let size = CGSize(width: label.frame.width, height: .greatestFiniteMagnitude) let options = NSStringDrawingOptions.usesFontLeading.union(.usesLineFragmentOrigin) let attributes = [NSAttributedString.Key.font: label.font] let boundingRect = text.boundingRect(with: size, options: options, attributes: attributes, context: nil) let height = ceil(boundingRect.height) ``` 4. 更新UILabel的frame属性,将高度设置为计算出的合适高度。 ``` label.frame.size.height = height ``` 通过以上步骤,我们就可以实现UILabel高度自适应。当文本内容改变时,只需要重新计算高度并更新UILabel的frame即可。这样就能确保UILabel始终能够完整显示文本内容,而不会出现截断。 ### 回答2: 在Swift中,可以通过以下步骤实现UILabel高度自适应: 1. 首先,我们需要将UILabel的numberOfLines属性设置为0,表示可以显示任意行数的文本。 ```swift label.numberOfLines = 0 ``` 2. 接下来,需要设置UILabel的宽度约束,即限制UILabel的宽度,以便计算文本在给定宽度下的高度。 ```swift label.widthAnchor.constraint(equalToConstant: desiredWidth).isActive = true ``` 3. 然后,使用UILabel的text属性来设置要显示的文本内容。 ```swift label.text = "这是要显示的文本内容" ``` 4. 最后,在对UILabel的布局进行更新之后,我们需要调用UILabel的sizeToFit()方法来计算并适应UILabel高度。 ```swift label.sizeToFit() ``` 完成这些步骤后,UILabel将根据显示的文本内容自动调整高度,以适应所设置的宽度约束。 需要注意的是,当UILabel文本过长时,自适应的高度可能会导致UILabel的宽度变窄,以保持文本的显示完整性。 ### 回答3: UILabel 在 Swift 中可以通过使用 `sizeToFit()` 方法来实现高度自适应。 sizeToFit() 方法用于根据UILabel中的文本内容调整其大小,以确保文本内容不被截断。当调用这个方法时,UILabel会根据当前设置的字体、文本内容和自动布局约束来自动计算并调整其大小。 首先,创建一个UILabel对象,并设置其属性,比如文本内容、字体大小和布局约束。 ```swift let label = UILabel() label.text = "这是一个需要自适应高度UILabel" label.font = UIFont.systemFont(ofSize: 16) label.numberOfLines = 0 // 设置为0表示自动换行 // 设置UILabel的宽度约束 let maxWidth = UIScreen.main.bounds.width - 20 // 假设UILabel的最大宽度是屏幕宽度减去左右边距 label.widthAnchor.constraint(lessThanOrEqualToConstant: maxWidth).isActive = true ``` 接下来,调用`sizeToFit()`方法来自动计算并调整UILabel的大小。 ```swift label.sizeToFit() ``` 通过以上代码,UILabel高度会根据文本内容自动计算并调整,确保文本不会被截断。UILabel会根据字体大小和布局约束,自动计算所需的高度。 最后,可以通过如下代码将UILabel添加到父视图中。 ```swift parentView.addSubview(label) ``` 这样,UILabel就会根据文本内容自动调整高度,并显示在父视图中。 通过使用以上的方法,就可以实现UILabel高度自适应功能。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值