iOS文字自适应 浅谈

 在开发项目中难免会遇到一个富文本,需要用到文字自适应. 下面的方法中我们可以很好的去解决这个问题

 .h

@interface UILabel (HCL)

+ (CGFloat)getHeightByWidth:(CGFloat)width title:(NSString *)title font:(UIFont*)font;

 

+ (CGFloat)getWidthWithTitle:(NSString *)title font:(UIFont *)font;

@end

 

@implementation UILabel (HCL)

+ (CGFloat)getHeightByWidth:(CGFloat)width title:(NSString *)title font:(UIFont *)font

{

    

    UILabel *label = [[UILabel alloc] initWithFrame:CGRectMake(0, 0, width, 0)];

    label.text = title;

    label.font = font;

    label.numberOfLines = 0;

    [label sizeToFit];

    CGFloat height = label.frame.size.height;

    return height;

}

 

+ (CGFloat)getWidthWithTitle:(NSString *)title font:(UIFont *)font {

    UILabel *label = [[UILabel alloc] initWithFrame:CGRectMake(0, 0, 1000, 0)];

    label.text = title;

    label.font = font;

    [label sizeToFit];

    return label.frame.size.width;

}

@end

 

 在使用的时候:

 

   //标题

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

    NSString * titleStr =@"走自己的路让别人说去吧,走自己的路让别人说去吧,走自己的路让别人说去吧";

    titleLabel.text = titleStr;

    //titleLabel.backgroundColor = [UIColor redColor];

    titleLabel.numberOfLines = 0;               ------>这句不能忘

    titleLabel.lineBreakMode = NSLineBreakByCharWrapping;

    titleLabel.textColor = [UIColor blackColor];

    titleLabel.font = [UIFont systemFontOfSize:16.0f];------>这句字体大小要跟下面对应

    [backgroundImageView addSubview:titleLabel];

 

 

[titleLabel mas_makeConstraints:^(MASConstraintMaker *make) {

        make.left.mas_equalTo(self.view.mas_left).offset(40);

        make.right.mas_equalTo(self.view.mas_right).offset(-40);

        make.top.mas_equalTo(self.view.mas_top).offset(30);

        make.height.mas_equalTo([UILabel getHeightByWidth:WIDTH-60 title:titleStr font:[UIFont systemFontOfSize:16.0f]]);------>对应

    }];

 

 

   希望能对大家项目中有帮助.

 

转载于:https://www.cnblogs.com/siwenss/p/6433681.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值