label适应文字

本文将详细探讨如何利用Objective-C和Swift在iOS开发中高效地显示文本,并通过定制字体、调整布局和优化文本样式来提升应用的用户体验。我们将介绍文本框的创建、文本内容的配置、以及如何根据需求动态调整文本显示效果,包括字体选择、字号调整和文本换行策略。此外,还会涉及如何通过属性字符串(NSAttributedString)来进一步丰富文本呈现,包括颜色、加粗、斜体等样式,并演示如何在不同设备上保持一致的显示效果。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

//第一种:显示全部

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

    CGSize size = CGSizeMake(320,2000);

    CGSize labelsize = [str sizeWithFont:font constrainedToSize:size lineBreakMode:UILineBreakModeWordWrap];

    label.frame = CGRectMake(view.frame.origin.x + view.frame.size.width + 10, view.frame.origin.y, labelsize.width, labelsize.height);


// 第二种:只能显示一部分

     NSDictionary *dic = [NSDictionary dictionaryWithObjectsAndKeys:label.font, @"NSFontAttributeName", nil];

    CGRect frame = [str boundingRectWithSize:CGSizeMake(1000, 1000) options:NSStringDrawingUsesLineFragmentOrigin attributes:dic context:nil];

    frame.origin.x = view.frame.origin.x + view.frame.size.width + 10;

    frame.origin.y = view.frame.origin.y;

    label.frame = frame;


//第三种:比第二种显示得更少一些

    NSAttributedString *attrStr = [[NSAttributedString alloc] initWithString:label.text];

    label.attributedText = attrStr;

    NSRange range = NSMakeRange(0, attrStr.length);

    //获取该段attributedString的属性字典

    NSDictionary *dic = [attrStr attributesAtIndex:0 effectiveRange:&range];

    //计算文本的大小

    CGSize textSize = [label.text boundingRectWithSize:label.bounds.size options:NSStringDrawingUsesLineFragmentOrigin attributes:dic context:nil].size;

    label.frame = CGRectMake(view.frame.origin.x + view.frame.size.width + 10, view.frame.origin.y, textSize.width, textSize.height);


//第四种:算高

    NSDictionary *dic = @{NSFontAttributeName:[UIFont systemFontOfSize:17]};

    CGRect rect = [self.evalDetail.descp boundingRectWithSize:CGSizeMake(WIDTH - 20, 10000) options:NSStringDrawingUsesLineFragmentOrigin attributes:dic context:nil];




评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值