iOS UILabel 設(shè)置漸變顏色字體

設(shè)置需要UILabel的字體、文本內(nèi)容與顏色數(shù)組后,調(diào)用setGradientLabel方法即可顯示

GradientLabel.h

    #import <UIKit/UIKit.h>

@interface GradientLabel : UILabel

- (void) setGradientLabelColors: (NSArray *)colors;

@end

GradientLabel.m

    #import "GradientLabel.h"

@interface GradientLabel ()

@property (nonatomic, strong) UILabel *label;

@property (nonatomic, strong) CAGradientLayer *gradientLayer;

@property (nonatomic, strong) NSArray * colors;//顏色數(shù)組

@end

@implementation GradientLabel

- (CAGradientLayer *)gradientLayer {
    if (!_gradientLayer) {
        _gradientLayer = [CAGradientLayer layer];
        _gradientLayer.startPoint = CGPointMake(0.0,1.0);
        _gradientLayer.endPoint = CGPointMake(1.0, 1.0);
        _gradientLayer.frame = self.label.frame;
        _gradientLayer.colors = self.colors?:@[[UIColor whiteColor], [UIColor blackColor]];
    }
    return _gradientLayer;
}


- (void) setGradientLabelColors: (NSArray *)colors {
    
    self.colors = colors;
    
    if (self.label == nil) {
        self.label = [[UILabel alloc] init];
        [self addSubview:self.label];
    }
    
    self.label.text = self.text;
    [self.label setFont:self.font?:[UIFont systemFontOfSize:13]];
    [self.label setTextAlignment:self.textAlignment?:NSTextAlignmentLeft];
    
    // 清理text
    self.text = @"";
}

-(void)layoutSubviews {
    [super layoutSubviews];
    
    [self.label setFrame:self.bounds];
    
    // 這里必須重新addSublayer才會(huì)更新
    if (self.gradientLayer.sublayers != nil) {
        [self.gradientLayer removeFromSuperlayer];
    }
    [self.layer addSublayer:self.gradientLayer];
    self.gradientLayer.mask = self.label.layer;
}

@end

代碼地址:https://github.com/QDeveloper/GCGradientLabel

最后編輯于
?著作權(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),簡(jiǎn)書(shū)系信息發(fā)布平臺(tái),僅提供信息存儲(chǔ)服務(wù)。

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

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