zoukankan      html  css  js  c++  java
  • UILabel自适应高、宽

    根据Label和字体大小自适应高度

    复制代码
    - (void)getHeightWithLabel:(UILabel *)label andFontSize:(CGFloat)size
    {
        label.numberOfLines = 0;
        NSMutableAttributedString *labelString = [[NSMutableAttributedString alloc] initWithString:label.text];
        [labelString addAttribute:NSFontAttributeName value:[UIFont systemFontOfSize:size] range:NSMakeRange(0, [labelString length])];
        CGRect labelStringRect = [labelString boundingRectWithSize:CGSizeMake(self.view.frame.size.width-label.frame.origin.x*2, 9999) options:NSStringDrawingUsesLineFragmentOrigin context:nil];
        CGRect labelRect = label.frame;
        labelRect.size.height = labelStringRect.size.height;
        label.frame = labelRect;
        label.attributedText = labelString;
    }
    复制代码

    根据Label和字体大小自适应宽度

    复制代码
    - (void)getWidthWithLabel:(UILabel *)label andFontSize:(CGFloat)size
    {
        label.numberOfLines = 0;
        NSMutableAttributedString *labelString = [[NSMutableAttributedString alloc] initWithString:label.text];
        [labelString addAttribute:NSFontAttributeName value:[UIFont systemFontOfSize:size] range:NSMakeRange(0, [labelString length])];
        CGRect labelStringRect = [labelString boundingRectWithSize:CGSizeMake(9999, label.frame.size.height) options:NSStringDrawingUsesLineFragmentOrigin context:nil];
        CGRect labelRect = label.frame;
        labelRect.size.width = labelStringRect.size.width;
        label.frame = labelRect;
        label.attributedText = labelString;
    }
    复制代码
  • 相关阅读:
    React源码 React ref
    数组算法 电话号码组合
    字符串算法 计算子串原理
    React源码 React.Component
    字符串算法 反转单词原理讲解
    React源码 ReactElement
    前端设计模式 中介者模式
    前端设计模式 备忘录模式
    前端设计模式 命令模式
    模拟退火
  • 原文地址:https://www.cnblogs.com/pb89/p/4829198.html
Copyright © 2011-2022 走看看