iOS 7.0之前用sizeWithFont:(计算的不是很准确)
CGFloat width1=[(NSString *)obj sizeWithFont:[UIFont systemFontOfSize:16] constrainedToSize:CGSizeMake(1000, FONTHEIGHT)].width;
iOS 7.0之后用 boundingRectWithSize:
返回文本绘制所占据的矩形空间。
CGFloat width1=[(NSString *)obj boundingRectWithSize:CGSizeMake(1000, FONTHEIGHT) options:NSStringDrawingUsesLineFragmentOrigin attributes:@{NSFontAttributeName:[UIFont systemFontOfSize:16]} context:nil].size.width;
-
obj
是指要计算显示宽度的字符串 -
boundingRectWithSize
表示计算的宽高限制
计算高度时,需要宽度固定:CGSizeMake(1000, CGFLOAT_MAX)
这里的1000也可以用已经确定的控件的宽度替代self.label.width
计算结果表示在宽度最多为1000高度不限时,显示完全字符串需要的高度
计算宽度时,需要高度固定:CGSizeMake(CGFLOAT_MAX, 21)
同理21也可以用已知高度替换:self.label.height
计算结果表示在高度不超过21时,将给定的字符串现实完全需要的宽度 -
options
是文本绘制的附加选项
NSStringDrawingUsesLineFragmentOrigin 默认基线 -
attributes
字典格式,限定字符串显示的样式,一般限制字体较多
@{NSFontAttributeName:[UIFont systemFontOfSize:16]} -
context
包括一些信息,例如如何调整字间距以及缩放。最终,该对象包含的信息将用于文本绘制。一般写nil。
特殊情况
1、如果使用上述方法计算出结果后,将字符串赋值给UILabel显示,会遇到“宽度计算感觉是够的,但是字符串就是没显示完全”的情况。
-
这种情况是由于计算的结果是默认贴边显示时的宽度,但UILabel 自带内边距效果,且没有直接的属性可以设置内边距的值(安卓有...),所以有的字符串会显示不完全。
-
经测试:iPhoneX不会有这种问题(可能高级系统UILabel没有内边距了?),Xcode9.2上用xib试验,UILabel的左右内边距都是0.5的样子
-
解决办法一:手动+5(大于左右内边距之和,且小于一个字的宽度/高度)
-
解决办法二:就是网上查到的自定义UILabel,重写方法
#import <UIKit/UIKit.h>
//.h文件
@interface LyLabel : UILabel
@property (nonatomic, assign) UIEdgeInsets textInsets; // 控制字体与控件边界的间隙
@end
//.m文件
#import "LyLabel.h"
@implementation LyLabel
- (instancetype)init {
if (self = [super init]) {
_textInsets = UIEdgeInsetsZero;
}
return self;
}
//重写方法
- (instancetype)initWithFrame:(CGRect)frame {
if (self = [super initWithFrame:frame]) {
_textInsets = UIEdgeInsetsZero;
}
return self;
}
- (void)drawTextInRect:(CGRect)rect {
[super drawTextInRect:UIEdgeInsetsInsetRect(rect, _textInsets)];
}
@end
具体应用:
LyLabel *testLabel = [[LyLabel alloc] initWithFrame:CGRectMake(0.0f, 0.0f, 100.f, 24.0f)];
testLabel.backgroundColor = [UIColor whiteColor];
testLabel.textColor = [UIColor blackColor];
testLabel.font = [UIFont systemFontOfSize:16.0f];
testLabel.textInsets = UIEdgeInsetsMake(0.f, 15.f, 0.f, 0.f); // 设置左内边距(上、左、下、右)
总结一下,方便以后查看QAQ
网友评论