iOS-設(shè)置UILabel的內(nèi)邊距

Paste_Image.png

問題說明

默認(rèn)Label的顯示效果如下


很多情況下,需要如下有內(nèi)邊距的效果(注意第一行與最后一行文字與label的上下邊距

解決方案

為了解決這個(gè)問題,設(shè)計(jì)SFLabel如下,繼承自UILabel

#import "SFLabel.h"
#import <UIKit/UIKit.h>

@interface SFLabel ()
// 用來決定上下左右內(nèi)邊距,也可以提供一個(gè)借口供外部修改,在這里就先固定寫死
@property (assign, nonatomic) UIEdgeInsets edgeInsets;
@end

@implementation SFLabel


//下面三個(gè)方法用來初始化edgeInsets
- (instancetype)initWithFrame:(CGRect)frame
{
    if(self = [super initWithFrame:frame])
    {
        self.edgeInsets = UIEdgeInsetsMake(25, 0, 25, 0);
    }
    return self;
}

- (instancetype)initWithCoder:(NSCoder *)aDecoder
{
    if (self = [super initWithCoder:aDecoder]) {
        self.edgeInsets = UIEdgeInsetsMake(25, 0, 25, 0);
    }
    return self;
}

- (void)awakeFromNib
{
   [super awakeFromNib];
    self.edgeInsets = UIEdgeInsetsMake(25, 0, 25, 0);
}

// 修改繪制文字的區(qū)域,edgeInsets增加bounds
-(CGRect)textRectForBounds:(CGRect)bounds limitedToNumberOfLines:(NSInteger)numberOfLines
{

    /*
    調(diào)用父類該方法
    注意傳入的UIEdgeInsetsInsetRect(bounds, self.edgeInsets),bounds是真正的繪圖區(qū)域
    */
    CGRect rect = [super textRectForBounds:UIEdgeInsetsInsetRect(bounds,
     self.edgeInsets) limitedToNumberOfLines:numberOfLines];
    //根據(jù)edgeInsets,修改繪制文字的bounds
    rect.origin.x -= self.edgeInsets.left;
    rect.origin.y -= self.edgeInsets.top;
    rect.size.width += self.edgeInsets.left + self.edgeInsets.right;
    rect.size.height += self.edgeInsets.top + self.edgeInsets.bottom;
    return rect;
}

//繪制文字
- (void)drawTextInRect:(CGRect)rect
{
    //令繪制區(qū)域?yàn)樵紖^(qū)域,增加的內(nèi)邊距區(qū)域不繪制
    [super drawTextInRect:UIEdgeInsetsInsetRect(rect, self.edgeInsets)];
}

@end

將UIlabel的類型改為SFLabel,看看現(xiàn)在效果是否如第二幅圖??。

注意事項(xiàng)

  • 通過SFLabel中的方法修改UILabel的內(nèi)邊距最好只修改上下內(nèi)邊距,通過系統(tǒng)NSMutableParagraphStyle可以修改左邊內(nèi)邊距;
  • 通過boundingRectWithSize:options:attributes:context:計(jì)算SFLabel內(nèi)容計(jì)算出的區(qū)域仍然是與直接使用UILabel的結(jié)果一樣,因此需要小心使用,可以在boundingRectWithSize:options:attributes:context:基礎(chǔ)上根據(jù)edgeInsets進(jìn)行修正。

SFLabel源碼

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時(shí)請(qǐng)結(jié)合常識(shí)與多方信息審慎甄別。
平臺(tái)聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡書系信息發(fā)布平臺(tái),僅提供信息存儲(chǔ)服務(wù)。
禁止轉(zhuǎn)載,如需轉(zhuǎn)載請(qǐng)通過簡信或評(píng)論聯(lián)系作者。

相關(guān)閱讀更多精彩內(nèi)容

友情鏈接更多精彩內(nèi)容