zoukankan      html  css  js  c++  java
  • iOS 根据字体调整UILabel的大小

    在大多数情况下,给UILabel进行动态数据绑定的时候,往往需要根据字符串的多少,动态调整UILabel的宽度或高度

    下面分两种情况:

    1、 UILabel的宽度不变,根基字体的多少,自动调整UILabel的高度,并折行显示

    UILabel *label = [[UILabel alloc] initWithFrame:CGRectMake(0, 10, 200, 20)];  
    label.font = [UIFont boldSystemFontOfSize:20.0f];  //UILabel的字体大小  
    label.numberOfLines = 0;  //必须定义这个属性,否则UILabel不会换行  
    label.textColor = [UIColor whiteColor];   
    label.textAlignment = NSTextAlignmentLeft;  //文本对齐方式  
    [label setBackgroundColor:[UIColor redColor]];  
      
    //宽度不变,根据字的多少计算label的高度  
    NSString *str = @"可以更改此内容进行测试,宽度不变,高度根据内容自动调节";  
    CGSize size = [str sizeWithFont:label.font constrainedToSize:CGSizeMake(label.frame.size.width, MAXFLOAT) lineBreakMode:NSLineBreakByWordWrapping];  
    //根据计算结果重新设置UILabel的尺寸  
    [label setFrame:CGRectMake(0, 10, 200, size.height)];  
    label.text = str;  
      
    [self.view addSubview:label];  
    [label release]; 

    2、 UILabel的高度不变,根据字体的多少,自动调整

    UILabel *label = [[UILabel alloc] initWithFrame:CGRectMake(0, 10, 20, 20)];  
    label.font = [UIFont boldSystemFontOfSize:20.0f];  //UILabel的字体大小  
    label.numberOfLines = 0;  //必须定义这个属性,否则UILabel不会换行  
    label.textColor = [UIColor whiteColor];   
    label.textAlignment = NSTextAlignmentLeft;  //文本对齐方式  
    [label setBackgroundColor:[UIColor redColor]];  
      
    //高度固定不折行,根据字的多少计算label的宽度  
    NSString *str = @"高度不变获取宽度,获取字符串不折行单行显示时所需要的长度";  
    CGSize size = [str sizeWithFont:label.font constrainedToSize:CGSizeMake(MAXFLOAT, label.frame.size.height)];  
    NSLog(@"size.width=%f, size.height=%f", size.width, size.height);  
    //根据计算结果重新设置UILabel的尺寸  
    [label setFrame:CGRectMake(0, 10, size.width, 20)];  
    label.text = str;  
      
    [self.view addSubview:label];  
    [label release];  
  • 相关阅读:
    字体向上滚动
    地图改变图层
    移动地图
    [转] nodejs安装不了和npm安装失败的解决方法
    git回滚merge
    处理网站缓存问题
    webpack初学笔记 之 小案例篇demo1
    正则表达式整理
    关于返回值为图片 音频 视频的处理
    jquery ui datepicker 插件如何设置只能选择日期 禁止输入日期
  • 原文地址:https://www.cnblogs.com/anyezhuixing/p/4548447.html
Copyright © 2011-2022 走看看