zoukankan      html  css  js  c++  java
  • IOS ——UI篇—— 自适应UILable高度 或宽 的设置

    我们在使用UILable时,在初始化的时候往往都是设置的固定的宽和高,在显示不同长度的文本时达不到我们想要的视觉效果,或者是不能显示完稍长的文本内容,满足不了我们的需求,

    我们可以根据文本的长度自动调节lable的高 或 宽

    //初始化时设置的size可以随便(此时的size会根据文本的多少自动调节)

     _titleLable = [[UILabel alloc]initWithFrame:CGRectMake(0, 0, WIDTH, 100)];

            _titleLable.textAlignment = NSTextAlignmentCenter;

        _titleLable.numberOfLines = 0;//此时行数必须设置(不设置行数当文本内容过多时,会只在lable的中央显示一行内容其余内容不会显示);   

        UIFont * tfont = [UIFont systemFontOfSize:24];

        _titleLable.font = tfont;

        _titleLable.lineBreakMode =NSLineBreakByTruncatingTail ;

        _titleLable.text = @"我们在使用UILable时,在初始化的时候往往都是设置的固定的宽和高,在显示不同长度的文本时达不到我们想要的视觉效果,或者是不能显示完稍长的文本内容,满足不了我们的需求" ;

        

        [_titleLable setBackgroundColor:[UIColor redColor]];

        

        //高度估计文本大概要显示几行,宽度根据需求自己定义。 MAXFLOAT 可以算出具体要多高

        

        CGSize titleSize =CGSizeMake(WIDTH,60);

        

        // label可设置的最大高度和宽度

        //    CGSize size = CGSizeMake(300.f, MAXFLOAT);    

        //    获取当前文本的属性

        NSDictionary * tdic = [NSDictionary dictionaryWithObjectsAndKeys:tfont,NSFontAttributeName,nil];

        //ios7方法,获取文本需要的size,限制宽度

        CGSize  actualTitleSize =[_message.newsName boundingRectWithSize:titleSize options:NSStringDrawingUsesLineFragmentOrigin  attributes:tdic context:nil].size;

     //此时设置的frame起到关键的作用 ,在此根据需要也可以用  actualTitleSize.width  自动调节lable的宽

        _titleLable.frame =CGRectMake(10,10, 375 - 20, actualTitleSize.height);

        [self.view addSubview:_titleLable];

     

    这样就能达到自动调节lable的高 或 宽 的目的了,如果你有更好

    感谢您的访问! 若对您有帮助或有兴趣请关注博客:http://www.cnblogs.com/Rong-Shengcom/
  • 相关阅读:
    kerberos
    BZOJ 3309 莫比乌斯反演
    Pollard_rho定理 大数的因数个数 这个板子超级快
    POJ 3171 区间覆盖最小值&&线段树优化dp
    拼题 L2-001 紧急救援 最短路计数+记录路径
    HDU 6464 权值线段树 && HDU 6468 思维题
    HDU 1394 线段树求逆序对
    [Poi2010]Bridges 最大流+二分答案 判定混合图欧拉回路
    01背包 多重背包 复习 模板
    CF 2018 Battle of Brains GYM 102062 F
  • 原文地址:https://www.cnblogs.com/Rong-Shengcom/p/5003359.html
Copyright © 2011-2022 走看看