iOS動態(tài)調整UILabel高度的幾種方法
簡介
UILabel類實現了一個只讀文本視圖。您可以使用這個類來畫一個或多個行靜態(tài)文本,比如你可能使用確定的其他部分的用戶界面。UILabel類支持既簡單又復雜的樣式標簽的文本,還可以控制外觀,比如標簽是否使用一個影子或吸引了一大亮點。
在iOS程序中,看的見、摸得著的,都是UIView的子類。UILabel是一個用于顯示文字信息的標簽視圖類,即UIView的子類。
以下是關于UILabel的官方網址:https://developer.apple.com/reference/uikit/uilabel
引言
有時我們需要根據UILabel內部的字體格式(包括字體大小,行間距)來動態(tài)調整UILabel的高度。
筆者在這里提供了兩個方法,可以根據UILabel內部特定的字體,行間距,UILabel寬度來獲得UILabel內部的真是高度。
動態(tài)調整Label的高度一共分為三個步驟:
- 獲得具有特定格式的AttributedString。
- 根據AttributedString來獲得新高度。
- 重新設置Label的高度。
#示例Demo
筆者通過同時顯示具有相同內容的Label來對比一下有 無動態(tài)調整高度 的情況。
##實現步驟:
####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 圖文混排(CoreText.framework)詳解及實例
這篇文章主要介紹了IOS 圖文混排(CoreText.framework)詳解及實例的相關資料,這里對IOS 的圖文混排進行了詳細介紹,并附代碼實例,和實現效果圖,需要的朋友可以參考下2016-11-11

