解决NSAttributedString与UILabel高度自适应计算问题

    xiaoxiao2021-03-25  51

    转: http://www.cnblogs.com/haohao-developer/p/5583482.html

    解决NSAttributedString与UILabel高度自适应计算问题

    两个类扩展方法:

    /**

     *  修改富文本的颜色

     *

     *  @param str   要改变的string

     *  @param color 设置颜色

     *  @param range 设置颜色的文字范围

     *

     *  @return 新的AttributedString

     */

    - (NSMutableAttributedString *)setTextColorWithStr:(NSString *)str Color:(UIColor *)color Range:(NSRange)range;

     

    /**

     *  修改富文本的字体

     *

     *  @param str   要改变的string

     *  @param font  设置字体

     *  @param range 设置字体的文字范围

     *

     *  @return 新的AttributedString

     */

    - (NSMutableAttributedString *)setTextFontWithStr:(NSString *)str Font:(UIFont *)font Range:(NSRange)range;

     

    两个类扩展方法的实现:

    - (NSMutableAttributedString *)setTextColorWithStr:(NSString *)str Color:(UIColor *)color Range:(NSRange)range{

        if (str == nil) return nil;

        NSMutableAttributedString *newStr = [[NSMutableAttributedString alloc] initWithString:str];

        [newStr addAttribute:NSForegroundColorAttributeName value:color range:range];

        return newStr;

    }

    - (NSMutableAttributedString *)setTextFontWithStr:(NSString *)str Font:(UIFont *)font Range:(NSRange)range{

         if (str == nil) return nil;

         NSMutableAttributedString *newStr = [[NSMutableAttributedString alloc] initWithString:str];

        [newStr addAttribute:NSFontAttributeName value:font range:range];

        return newStr;

    }

     

    //消息内容frame

    //先给定一个宽度,高度无限大

    CGFloat CommenntWidth = 300;

        CGSize maxSize = CGSizeMake(CommenntWidth, MAXFLOAT);

    //设定attributedString的字体及大小,一定要设置这个,否则计算出来的height是非常不准确的

        [attributedString addAttribute:NSFontAttributeName value:BKFont(16) range:RANGE(0, attributedString.length)];

    //计算attributedString的rect

        _contentRect = [attributedString boundingRectWithSize:maxSize options:NSStringDrawingUsesLineFragmentOrigin context:nil];

    转载请注明原文地址: https://ju.6miu.com/read-35404.html

    最新回复(0)