博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
根据字体多少使UILabel自动调节尺寸
阅读量:6686 次
发布时间:2019-06-25

本文共 1516 字,大约阅读时间需要 5 分钟。

转自于: 

分两种情况考虑:

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

代码如下:

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

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

代码如下:

1     UILabel *label = [[UILabel alloc] initWithFrame:CGRectMake(0, 10, 20, 20)]; 2     label.font = [UIFont boldSystemFontOfSize:20.0f];  //UILabel的字体大小 3     label.numberOfLines = 0;  //必须定义这个属性,否则UILabel不会换行 4     label.textAlignment = NSTextAlignmentLeft;  //文本对齐方式 5      6     //高度固定不折行,根据字的多少计算label的宽度 7     NSString *str = @"高度不变获取宽度,获取字符串不折行单行显示时所需要的长度"; 8     CGSize size = [str sizeWithFont:label.font constrainedToSize:CGSizeMake(MAXFLOAT, label.frame.size.height)]; 9 10     //根据计算结果重新设置UILabel的尺寸11     [label setFrame:CGRectMake(0, 10, size.width, 20)];12     label.text = str;13     14     [self.view addSubview:label];

其中两种情况,核心代码均为size处的代码,均要把对应的size设置为MAXFLOAT

转载于:https://www.cnblogs.com/farer-zcz/p/3736419.html

你可能感兴趣的文章
测试LCD1602的显示,显示时间,提示语
查看>>
Linux常用命令
查看>>
SecureCRT 连接Ubuntu乱码解决
查看>>
一致性hash算法及其java实现
查看>>
PHP常见的加密技术
查看>>
Asp.net读取AD域信息的方法(一)
查看>>
两道题学习动态规划
查看>>
mysql实战31 | 误删数据后除了跑路,还能怎么办?
查看>>
ASP.NET MVC Razor
查看>>
Subscribe的第四个参数用法
查看>>
vue-cli的项目加入骨架屏
查看>>
3.SOAP和WSDL的一些必要知识
查看>>
python:使用OO和工厂模式解决问题
查看>>
C++学习-2
查看>>
mysql单表导入数据,全量备份导入单表
查看>>
GAITC 2019全球人工智能技术大会(南京)
查看>>
使用gradle生成protobuf
查看>>
transition transform animate的使用
查看>>
WebService_HelloWorld
查看>>
【翻译】Ext JS最新技巧——2014-5-12
查看>>