亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

iOS獲取Label高度的幾種方法與對比

 更新時間:2016年11月29日 10:17:36   作者:fuyoufang  
這篇文章主要介紹了給大家介紹了iOS獲取Label高度的幾種方法,包括 view的sizeThatFits 方法、view的sizeToFit方法、NSString的sizeWithAttributes方法和NSString 的 boundingRectWithSize 方法,文中不僅介紹四種方法的實現(xiàn),還進行了對比,下面來一起看看吧。

介紹

在設置 UILabel 的 Frame 高度時,不能簡單的設置為字體的 font size。否則會將字體的一部分裁剪掉。因為 UILabel 在不同的字體設置下,對 Frame 的高度要求也不一樣,大多數(shù)情況下都比Font的高度設置要高一些。

一、sizeThatFits

使用 view sizeThatFits 方法。

// return 'best' size to fit given size. does not actually resize view. Default is return existing view size
- (CGSize)sizeThatFits:(CGSize)size;

例子:

UILabel *testLabel = [[UILabel alloc] init];
testLabel.font = [UIFont systemFontOfSize:30];
testLabel.text = @"Today is a fine day";
CGSize size = [testLabel sizeThatFits:CGSizeMake(200, 30)];
NSLog(@"size = %@", NSStringFromCGSize(size));

輸出:size = {246.33333333333334, 36}

二、sizeToFit

使用 view sizeToFit 方法。

注意:sizeToFit 會改變 view 原來的 bounds,而 sizeThatFits 不會。

// calls sizeThatFits: with current view bounds and changes bounds size.
- (void)sizeToFit;

例子

UILabel *testLabel = [[UILabel alloc] init];
testLabel.font = [UIFont systemFontOfSize:30];
testLabel.text = @"Today is a fine day";
[testLabel sizeToFit];
NSLog(@"size = %@", NSStringFromCGSize(testLabel.frame.size));

輸出:size = {246.33333333333334, 36}

三、sizeWithAttributes

使用 NSString sizeWithAttributes 方法。

- (CGSize)sizeWithAttributes:(nullable NSDictionary<NSString *, id> *)attrs NS_AVAILABLE(10_0, 7_0);

例子

NSString *text = @"Today is a fine day";
UIFont *font = [UIFont systemFontOfSize:30];
CGSize size = [text sizeWithAttributes:@{
           NSFontAttributeName : font
           }];
NSLog(@"size = %@", NSStringFromCGSize(size));

輸出: size = {246.3134765625, 35.80078125}

四、boundingRectWithSize

使用 NSString boundingRectWithSize 方法。

// NOTE: All of the following methods will default to drawing on a baseline, limiting drawing to a single line.
// To correctly draw and size multi-line text, pass NSStringDrawingUsesLineFragmentOrigin in the options parameter.
- (CGRect)boundingRectWithSize:(CGSize)size options:(NSStringDrawingOptions)options attributes:(nullable NSDictionary<NSString *, id> *)attributes context:(nullable NSStringDrawingContext *)context NS_AVAILABLE(10_11, 7_0);

參數(shù)的意義:

1、size

限制最大寬高, 雖然是自適應,但是需要限制最大的寬度和高度。

2、options

類型為 NSStringDrawingOptions,用來指明繪制字符串時的渲染選項。

各個選項如下:

typedef NS_OPTIONS(NSInteger, NSStringDrawingOptions) {
 // The specified origin is the line fragment origin, not the base line origin
 // 整個文本將以每行組成的矩形為單位計算整個文本的尺寸
 NSStringDrawingUsesLineFragmentOrigin = 1 << 0, 

 // Uses the font leading for calculating line heights
 // 使用字體的行間距來計算文本占用的范圍,即每一行的底部到下一行的底部的距離計算
 NSStringDrawingUsesFontLeading = 1 << 1, 

 // Uses image glyph bounds instead of typographic bounds
 // 將文字以圖像符號計算文本占用范圍,而不是排版的邊界
 NSStringDrawingUsesDeviceMetrics = 1 << 3,

 // Truncates and adds the ellipsis character to the last visible line if the text doesn't fit into the bounds specified.
 // Ignored if NSStringDrawingUsesLineFragmentOrigin is not also set.
 // 如果文本內(nèi)容超出指定的矩形限制,文本將被截去并在最后一個字符后加上省略號。
 // 如果 NSStringDrawingUsesLineFragmentOrigin 沒有設置,則該選項不生效
 NSStringDrawingTruncatesLastVisibleLine NS_ENUM_AVAILABLE(10_5, 6_0) = 1 << 5, 
} NS_ENUM_AVAILABLE(10_0, 6_0);

三、attributes

應用于字符串的文本屬性。

四、context

NSStringDrawingContext 類型,控制調(diào)整字間距和縮放的比例,用于文本繪制時使用。該參數(shù)傳入 nil 即可。

例子

NSString *text = @"Today is a fine day";
UIFont *font = [UIFont systemFontOfSize:30];
CGRect suggestedRect = [text boundingRectWithSize:CGSizeMake(800, MAXFLOAT)
            options:NSStringDrawingUsesFontLeading
           attributes:@{ NSFontAttributeName : font }
            context:nil];
NSLog(@"size = %@", NSStringFromCGSize(suggestedRect.size));

輸出: size = {200, 35.80078125}

四種方式對比

在設置字體為 30 的情況下,前兩種使用 view 的方法返回 size = {246.33333333333334, 36} ,后兩種使用 NSString 的方法返回 size = {246.3134765625, 35.80078125} 。使用 view 方法比使用  NSString 方法的返回的值略大。

我猜測其原因都是因為,文本渲染引擎在渲染一行文本的時候都需要在label的頂部和底部預留一小部分空間,應該是出于排版美觀方面的考量。

在顯示不同的 font size 的字體時,獲得的字符串高度比 font size 大的值是不同的。

比如 font size 為 13 時,算出高度為 16,font size 為 20 時,算出高度為 24。

所以平常設置 UILabel 高度的時候,也不能簡單的在 font height 基礎之上加隨意值。

總結

以上就是這篇文章的全部內(nèi)容了,希望本文的內(nèi)容對給位iOs開發(fā)者們能有所幫助,如果有疑問大家可以留言交流。

相關文章

  • MAUI模仿iOS多任務切換卡片滑動的交互實現(xiàn)代碼

    MAUI模仿iOS多任務切換卡片滑動的交互實現(xiàn)代碼

    這篇文章主要介紹了[MAUI]模仿iOS多任務切換卡片滑動的交互實現(xiàn),使用.NET MAU實現(xiàn)跨平臺支持,本項目可運行于Android、iOS平臺,需要的朋友可以參考下
    2023-05-05
  • IOS 繪制三角形的實例詳解

    IOS 繪制三角形的實例詳解

    這篇文章主要介紹了IOS 繪制三角形的實例詳解的相關資料,希望通過本文大家能夠?qū)崿F(xiàn)三角形的繪制,需要的朋友可以參考下
    2017-09-09
  • iOS應用開發(fā)中UITableView的分割線的一些設置技巧

    iOS應用開發(fā)中UITableView的分割線的一些設置技巧

    這篇文章主要介紹了iOS應用開發(fā)中UITableView分割線的一些設置技巧,包括消除分割線的方法,示例代碼為傳統(tǒng)的Objective-C語言,需要的朋友可以參考下
    2016-03-03
  • Objective-C中利用正則去除非數(shù)字字母漢字方法實例

    Objective-C中利用正則去除非數(shù)字字母漢字方法實例

    正則表達式對我們?nèi)粘i_發(fā)來說是必不可少的,下面這篇文章主要給大家介紹了關于Objective-C中如何利用正則去除非數(shù)字字母漢字的相關資料,文中通過示例代碼介紹的非常詳細,需要的朋友可以參考借鑒,下面隨著小編來一起學習學習吧
    2018-06-06
  • xcode 4 制作靜態(tài)庫圖文詳解

    xcode 4 制作靜態(tài)庫圖文詳解

    我這個文檔的靜態(tài)庫的開發(fā)是基于Xcode4.2和iOS SDK5.0編寫的。Xcode4跟之前的Xcode3還是有不少的差別的
    2013-06-06
  • iOS瀑布流的簡單實現(xiàn)(Swift)

    iOS瀑布流的簡單實現(xiàn)(Swift)

    這篇文章主要介紹了iOS瀑布流的簡單實現(xiàn),說到瀑布流, 或許大家都不陌生, 瀑布流的實現(xiàn)也有很多種! 本文使用兩種方法介紹,有興趣的可以了解一下。
    2016-11-11
  • 基于IOS實現(xiàn)帶箭頭的view

    基于IOS實現(xiàn)帶箭頭的view

    這篇文章封裝了一個比較常用的控件, 帶箭頭的View, iOS在很多場景下可以使用到帶箭頭的View,下面一起來學習學習。
    2016-08-08
  • iOS開發(fā)中Swift3 監(jiān)聽UITextView文字改變的方法(三種方法)

    iOS開發(fā)中Swift3 監(jiān)聽UITextView文字改變的方法(三種方法)

    在項目中使用文本輸入框出UITextField之外還會經(jīng)常使用 UITextView ,難免會有需求監(jiān)聽UITextView文本框內(nèi)文本數(shù)量.下面介紹在swift3中兩種常用方式,需要的朋友參考下吧
    2016-11-11
  • iOS使用UIScrollView實現(xiàn)無限循環(huán)輪播圖效果

    iOS使用UIScrollView實現(xiàn)無限循環(huán)輪播圖效果

    這篇文章主要介紹了iOS使用UIScrollView實現(xiàn)無限循環(huán)輪播圖效果,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2018-07-07
  • iOS實現(xiàn)貝塞爾曲線動畫

    iOS實現(xiàn)貝塞爾曲線動畫

    這篇文章主要為大家詳細介紹了iOS實現(xiàn)貝塞爾曲線動畫,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2021-08-08

最新評論