iOS获取字符串在Label上显示的bounds

cell自适应高度时需要计算label上显示字符串后的大小,根据字符串的方法boundingRectWithSize实现。
OC代码:扩展NSString

- (CGRect)boundsWithConstrainedWidth:(CGFloat)width WithFont:(UIFont *)font {
    NSDictionary *attributes = @{ NSFontAttributeName : [UIFont systemFontOfSize:16] };
    CGRect rect = [self boundingRectWithSize:CGSizeMake([UIScreen mainScreen].bounds.size.width - 55, 1000) options:NSStringDrawingUsesLineFragmentOrigin|NSStringDrawingUsesFontLeading attributes:attributes context:nil];
    return rect;
}

- (CGFloat)widthWithConstrainedWidth:(CGFloat)width WithFont:(UIFont *)font {
    return [self boundsWithConstrainedWidth:width WithFont:font].size.width;
}

- (CGFloat)heightWithConstrainedWidth:(CGFloat)width WithFont:(UIFont *)font {
    return [self boundsWithConstrainedWidth:width WithFont:font].size.height;
}

Swift代码:扩展String

extension String {
    func boundsWithConstrainedWidth(width: CGFloat, font: UIFont) -> CGRect {
        let constraintRect = CGSize(width: width, height: CGFloat.greatestFiniteMagnitude)
        let bounds = self.boundingRect(with: constraintRect, options: NSStringDrawingOptions.usesLineFragmentOrigin, attributes: [NSFontAttributeName: font], context: nil)
        return bounds
    }
    func widthWithConstrainedWidth(width: CGFloat, font: UIFont) -> Float {
        let constraintRect = CGSize(width: width, height: CGFloat.greatestFiniteMagnitude)
        let bounds = self.boundingRect(with: constraintRect, options: NSStringDrawingOptions.usesLineFragmentOrigin, attributes: [NSFontAttributeName: font], context: nil)
        return bounds.width
    }
    func heightWithConstrainedWidth(width: CGFloat, font: UIFont) -> CGFloat {
        let constraintRect = CGSize(width: width, height: CGFloat.greatestFiniteMagnitude)
        let bounds = self.boundingRect(with: constraintRect, options: NSStringDrawingOptions.usesLineFragmentOrigin, attributes: [NSFontAttributeName: font], context: nil)
        return bounds.height
    }
}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值