ios动态获取UILabel的高度和宽度

热门标签

特别声明:文章多为网络转载,资源使用一般不提供任何帮助,特殊资源除外,如有侵权请联系!

在使用UILabel存放字符串时,经常需要获取label的长宽数据,本文列出了部分常用的计算方法。

1.获取宽度,获取字符串不折行单行显示时所需要的长度
CGSize titleSize = [aString sizeWithFont:font constrainedToSize:CGSizeMake(MAXFLOAT, 30)];
注:如果想得到宽度的话,size的width应该设为MAXFLOAT。

2.获取高度,获取字符串在指定的size内(宽度超过label的宽度则换行)所需的实际高度.
CGSize titleSize = [aString sizeWithFont:font constrainedToSize:CGSizeMake(label.frame.size.width, MAXFLOAT) lineBreakMode:UILineBreakModeWordWrap];
注:如果想得到高度的话,size的height应该设为MAXFLOAT。


3.实际编程时,有时需要计算一段文字最后一个字符的位置,并在其后添加图片或其他控件(如info图标),下面代码为计算label中最后一个字符后面一位的位置的方法。
CGSize sz = [label.text sizeWithFont:label.font constrainedToSize:CGSizeMake(MAXFLOAT, 40)];
CGSize linesSz = [label.text sizeWithFont:label.font constrainedToSize:CGSizeMake(label.frame.size.width, MAXFLOAT) lineBreakMode:UILineBreakModeWordWrap];
if(sz.width <= linesSz.width) 
//判断是否折行
  { 
    lastPoint = CGPointMake(label.frame.origin.x + sz.width, label.frame.origin.y); 
   }else { 
    lastPoint = CGPointMake(label.frame.origin.x + (int)sz.width % (int)linesSz.width,linesSz.height - sz.height);
 }


带属性的字符串(NSMutableAttributedString)的使用**

1.创建对象  NSString *original = @"今天你还好吗?";  
NSMutableAttributedString *attrTitle = [[NSMutableAttributedStringalloc] initWithString:original];

2.设置颜色
(NSForegroundColorAttributeName代表要设置颜色, value代表值, range 代表范围)  /**    
其他设置:      
1.NSForegroundColorAttributeName //颜色      
2.NSFontAttributeName //字体      
3.NSBackgroundColorAttributeName //背景色
     //还有其他的很多的属性,可以自己去看苹果的API,这里不再详述  */  
[attrTitle addAttribute:NSForegroundColorAttributeName value:[UIColorblueColor] range:NSMakeRange(0, 2)];
3.添加到Label中 UILabel *label = [[UILabel alloc] init]; 
label.frame = CGRectMake(100, 100, 100, 40); 
[label setAttributedText:attrTitle]; [self.view addSubview:label];

标签:

未经允许不得转载:作者:SheaYang, 转载或复制请以 超链接形式 并注明出处 技术Dog|博客
原文地址:《ios动态获取UILabel的高度和宽度》 发布于2019-09-19

分享到:
赞(0) 打赏

评论 抢沙发

4 + 5 =


ios动态获取UILabel的高度和宽度

长按图片转发给朋友

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

微信扫一扫打赏

Vieu4.0主题
专业打造轻量级个人企业风格博客主题!专注于前端开发,全站响应式布局自适应模板。

登录

忘记密码 ?