博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
iOS之UILabel------分类创建label,计算文本大小
阅读量:4289 次
发布时间:2019-05-27

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

**********计算文本大小

//计算文本大小-(CGSize )caculateTextSizeWithStr:(NSString *)str fontsize:(CGFloat)fontsize width:(CGFloat)width height:(CGFloat)height{UILabel *lbl=[[UILabel alloc]initWithFrame:CGRectMake(0, 0, 375, 60)];    lbl.text=str;// 给 显示的文本一个区域CGSize contentMaxSizes = CGSizeMake(WIDTH, MAXFLOAT);    if(width==0){//已知高计算宽度        contentMaxSizes = CGSizeMake(MAXFLOAT, height);    }    if(height==0){//已知宽度计算高        contentMaxSizes = CGSizeMake(width, MAXFLOAT);    }// NSFontAttributeName 字体的大小 NSDictionary *attributesDicts = @{NSFontAttributeName:[UIFont systemFontOfSize:fontsize]};//计算文本实际宽高的时候, 计算的字体大小要和label中设置的字体大小保持一致// 根据限定的条件, 来计算text 真实的宽高    CGSize contentRealSizes = [lbl.text boundingRectWithSize:contentMaxSizes options:NSStringDrawingUsesLineFragmentOrigin attributes:attributesDicts context:nil].size;    return contentRealSizes;}

-(void)caculateTextSize{

    UILabel *lbl=[[UILabel alloc]initWithFrame:CGRectMake(0, 0, 375, 60)];

   // 方法一

    // 给 显示的文本一个区域

    CGSize contentMaxSizes = CGSizeMake(300, MAXFLOAT);

    // NSFontAttributeName 字体的大小

    NSDictionary *attributesDicts = @{

NSFontAttributeName:[UIFont systemFontOfSize:15]};

#warning 计算文本实际宽高的时候, 计算的字体大小要和label中设置的字体大小保持一致

    // 根据限定的条件, 来计算text 真实的宽高

    CGSize contentRealSizes =  [lbl.text boundingRectWithSize:contentMaxSizes options:NSStringDrawingUsesLineFragmentOrigin attributes:attributesDicts context:nil].size;

    

   // 方法二

    NSDictionary *attributesDict = @{

NSFontAttributeName:[UIFont systemFontOfSize:15]};

    CGSize contentRealSize =[lbl.text sizeWithAttributes:attributesDict];

    

    //方法三

    CGSize size = [lbl.text sizeWithFont:[UIFont boldSystemFontOfSize:15] constrainedToSize:contentMaxSizes lineBreakMode:UILineBreakModeCharacterWrap];

}

 

 

 

 

#import <UIKit/UIKit.h>

 

@interface UILabel (LYLabel)

//创建label

+(UILabel *)initLabelWithDict:(NSDictionary *)dict;

//计算label的大小

+(CGSize)caculateLabelSizeWithDict:(NSDictionary *)dict;

@end

 

#import "UILabel+LYLabel.h"

 

@implementation UILabel (LYLabel)

+(UILabel *)initLabelWithDict:(NSDictionary *)dict{

    UILabel *lbl=[[UILabelalloc]init];

    lbl.text=dict[@"title"];

    lbl.textColor=dict[@"titleColor"];

    lbl.font=dict[@"font"];

   

//    lbl.lineBreakMode =NSLineBreakByCharWrapping;//label的内容超出其大小时,其中lineBreakMode可选值为

 

//    linBreakMode enum{

//        NSLineBreakByWordWrapping = 0,//保留整个单词,以空格为边界

//        NSLineBreakByCharWrapping,//保留整个字符

//        NSLineBreakByClipping,//以边界为止

//        NSLineBreakByTruncatingHead,//省略开头,以省略号代替

//        NSLineBreakByTruncatingTail,//省略结尾,以省略号代替

//        NSLineBreakByTruncatingMiddle//省略中间,以省略号代替

//    }

//    lbl.adjustsFontSizeToFitWidth =YES;//文本自动根据label大小自动调整字体尺寸

//    [lbl sizeToFit];//label适应内容大小

 

    lbl.numberOfLines=0;//多行文本显示

    

    lbl.textAlignment=NSTextAlignmentCenter;//对齐方式

    lbl.highlighted=YES;

    lbl.highlightedTextColor=[UIColoryellowColor];//高亮时的文本颜色

    

 

    return lbl;

}

//+(CGSize)caculateLabelSizeWithDict:(NSDictionary *)dict{

//    //根据内容计算label的大小

//    UIFont *font =[UIFont fontWithName:@"Arial" size:12];

//    CGSize size = [dict[@"title"] boundingRectWithSize:<#(CGSize)#> options:<#(NSStringDrawingOptions)#> attributes:<#(nullable NSDictionary<NSAttributedStringKey,id> *)#> context:<#(nullable NSStringDrawingContext *)#>];

//

//

//    return size;

//}

 

调用:

    NSDictionary *dict=@{

                         @"title":@"firstasdfghjklpoiuytrewqazxcvbnmljjjllllllhggg",

                         @"titleColor":[UIColorgreenColor],

                         @"font":[UIFontsystemFontOfSize:30weight:UIFontWeightBold]

                         };

    UILabel *lbl=[UILabelinitLabelWithDict:dict];

    lbl.frame=CGRectMake(50,50,200, 50);

    [self.viewaddSubview:lbl];

 

@end

 

转载地址:http://ljmgi.baihongyu.com/

你可能感兴趣的文章
javascript原型对象存在的问题(3)
查看>>
javascript原型继承(1)
查看>>
javascript原型继承-实现extjs底层继承(2)
查看>>
javascript设计模式-建立接口的方式(1)
查看>>
javascript设计模式-单体singleton模式(2)
查看>>
javascript设计模式-链式编程(3)
查看>>
大型高并发与高可用缓存架构总结
查看>>
javascript设计模式-工厂模式(4)
查看>>
javascript设计模式-组合模式(6)
查看>>
javascript设计模式-门面模式(7)
查看>>
javascript设计模式-享元模式(10)
查看>>
javascript设计模式-代理模式(11)
查看>>
Executor相关源码分析
查看>>
react之setState解析
查看>>
elasticsearch7.3版本已经不需要额外安装中文分词插件了
查看>>
【重大好消息】elasticsearch 7.3版本已经可以免费使用x-pack就可以设置账号和密码了,让你的数据不再裸奔
查看>>
解决使用logstash中jdbc导入mysql中的数据到elasticsearch中tinyint类型被转成布尔型的问题的方法
查看>>
elasticsearch7.3版本环境搭建(一)elasticsearch安装和配置
查看>>
SEO基本功:站内优化的一些基本手段
查看>>
centos6系列和7系列如何对外开放80,3306端口号或者其他端口号
查看>>