iOS动态调整UILabel高度的几种方法

 更新时间:2017年12月17日 10:08:07   作者:J_Knight_  
在iOS编程中UILabel是一个常用的控件,下面这篇文章主要给大家介绍了关于iOS动态调整UILabel高度的几种方法,文中通过示例代码介绍的非常详细,需要的朋友可以参考借鉴,下面随着小编来一起学习学习吧。

简介

UILabel类实现了一个只读文本视图。您可以使用这个类来画一个或多个行静态文本,比如你可能使用确定的其他部分的用户界面。UILabel类支持既简单又复杂的样式标签的文本,还可以控制外观,比如标签是否使用一个影子或吸引了一大亮点。

在iOS程序中,看的见、摸得着的,都是UIView的子类。UILabel是一个用于显示文字信息的标签视图类,即UIView的子类。

以下是关于UILabel的官方网址:https://developer.apple.com/reference/uikit/uilabel

引言

有时我们需要根据UILabel内部的字体格式(包括字体大小,行间距)来动态调整UILabel的高度。

笔者在这里提供了两个方法,可以根据UILabel内部特定的字体,行间距,UILabel宽度来获得UILabel内部的真是高度。

动态调整Label的高度一共分为三个步骤:

  • 获得具有特定格式的AttributedString。
  • 根据AttributedString来获得新高度。
  • 重新设置Label的高度。

#示例Demo

笔者通过同时显示具有相同内容的Label来对比一下有 无动态调整高度 的情况。

##实现步骤:

####1. 获得具有特定格式的AttributedString

/**
 * 获取特定格式的属性字符串
 *
 * @param string 原字符串
 * @param font 字体
 * @param spacing 行间距
 *
 * @return 特定格式的属性字符串
 */
- (NSAttributedString *)attributedStringWithString: (NSString *)string andFont: (UIFont *)font andLineSpacing:(CGFloat)spacing
{
 NSMutableAttributedString *contentString = [[NSMutableAttributedString alloc] initWithString:string];
 [contentString addAttribute:NSFontAttributeName value:font range:NSMakeRange(0, contentString.length)];
 NSMutableParagraphStyle * paragraphStyle = [[NSMutableParagraphStyle alloc] init];
 [paragraphStyle setAlignment:NSTextAlignmentLeft];
 [paragraphStyle setLineSpacing:spacing];
 [contentString addAttribute:NSParagraphStyleAttributeName value:paragraphStyle range:NSMakeRange(0, [contentString length])]; 
 return [contentString copy];
}

####2. 根据AttributedString来获得高度

/**
 * 获取根据特定格式的属性字符串计算的新高度
 *
 * @param string  特定格式的属性字符串
 * @param maxWidth UILable的最宽宽度(换行点)
 *
 * @return 根据特定格式的属性字符串计算的新高度
 */
- (CGSize)sizeOfAttributedString: (NSAttributedString *)string withMaxWidth: (CGFloat)maxWidth
{
  CGRect rect = [string boundingRectWithSize:CGSizeMake(maxWidth, MAXFLOAT) options:NSStringDrawingUsesLineFragmentOrigin | NSStringDrawingUsesFontLeading context:nil];
  return rect.size;
}

####3. 重新设置Label的高度

NSAttributedString *string = [self attributedStringWithString:self.contentString andFont:[UIFont systemFontOfSize:15.0] andLineSpacing:2.0];
CGSize size = [self sizeOfAttributedString:string withMaxWidth:maxWidth];
self.resizeLabel.frame = CGRectMake((self.view.bounds.size.width - maxWidth)/2, 400, maxWidth, size.height);
self.resizeLabel.attributedText = string;

作为对比,显示具有相同格式内容的UILabel

self.orignalLabel.attributedText = [self attributedStringWithString:self.contentString andFont:[UIFont systemFontOfSize:15.0] andLineSpacing:2.0 ];

总结

以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作具有一定的参考学习价值,如果有疑问大家可以留言交流,谢谢大家对脚本之家的支持。

相关文章

  • 关于iOS 11的一些新特性适配实践总结

    关于iOS 11的一些新特性适配实践总结

    iOS 11 为整个生态系统的 UI 元素带来了一种更加大胆、动态的新风格。下面这篇文章主要给大家总结介绍了关于iOS 11的一些新特性适配实践,文中通过示例代码介绍的非常详细,需要的朋友可以参考借鉴,下面来一起看看吧。
    2017-11-11
  • ios实现UITableView之间圆角和间隙

    ios实现UITableView之间圆角和间隙

    这篇文章主要为大家详细介绍了ios实现UITableView之间圆角和间隙,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2017-08-08
  • iOS-GCD详解及简单使用

    iOS-GCD详解及简单使用

    这篇文章主要介绍了iOS-GCD详解的相关资料,并附简单的实例代码,帮助大家学习理解此部分的知识,需要的朋友可以参考下
    2016-11-11
  • IOS 图文混排(CoreText.framework)详解及实例

    IOS 图文混排(CoreText.framework)详解及实例

    这篇文章主要介绍了IOS 图文混排(CoreText.framework)详解及实例的相关资料,这里对IOS 的图文混排进行了详细介绍,并附代码实例,和实现效果图,需要的朋友可以参考下
    2016-11-11
  • iOS开发傻瓜式微信支付的方法教程

    iOS开发傻瓜式微信支付的方法教程

    最近因为工作的需要,要开发微信支付,发现网上的很多教程过于复杂,索性自己写一篇,所以下面这篇文章主要跟大家分享了关于iOS开发傻瓜式微信支付的方法教程,文中通过示例代码介绍的非常详细,需要的朋友们下面来一起看看吧。
    2017-07-07
  • iOS tabview如何添加字母索引

    iOS tabview如何添加字母索引

    这篇文章主要为大家详细介绍了iOS tabview如何添加字母索引,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2017-03-03
  • IOS 中KVC的使用方法实例详解

    IOS 中KVC的使用方法实例详解

    这篇文章主要介绍了IOS 中KVC的使用方法实例详解的相关资料,这提供具体使用方法,希望能帮助到大家,需要的朋友可以参考下
    2017-09-09
  • iOS QQ第三方登录实现

    iOS QQ第三方登录实现

    这篇文章主要介绍了iOS QQ第三方登录实现的全过程,一步一步告诉大家iOS QQ实现第三方登录的方法,感兴趣的小伙伴们可以参考一下
    2016-12-12
  • iOS如何用100行代码实现简单的抽屉效果

    iOS如何用100行代码实现简单的抽屉效果

    最近在网上看到一些抽屉效果,看起来很酷!很眩!但是,下不下来看代码, 所以决定还是自己写吧!!这篇文章通过近100行的代码就实现了简单的抽屉效果,有需要的朋友们可以参考借鉴,下面来一起看看吧。
    2016-10-10
  • IOS 性能优化中离屏渲染

    IOS 性能优化中离屏渲染

    本文主要介绍了IOS 性能优化中离屏渲染的资料,提供了几种方法讲解了优化,有需要的小伙伴可以参考下
    2016-10-10

最新评论