UILabel光晕文字效果

1、新建一个基于UILabel的子类

2、在这个子类中定义red、green、blue三个颜色值变量和一个发光光晕范围变量size。

3、复写UILable的drawTextInRect方法,并使用CGContextRef来进行光晕效果绘制。

基本思路就是这样子了,下面是部分主要代码:

.h文件

 1 //创建UILable的子类 GlowLable  
 2 @interface GlowLabel : UILabel  
 3   
 4 //定义颜色值全局变量和放大值全局变量  
 5 @property(assign,nonatomic)float redValue;  
 6 @property(assign,nonatomic)float greenValue;  
 7 @property(assign,nonatomic)float blueValue;  
 8 @property(assign,nonatomic)float size;  
 9   
10 @end

.m文件

 1 @implementation GlowLabel  
 2   
 3 @synthesize redValue;  
 4 @synthesize greenValue;  
 5 @synthesize blueValue;  
 6 @synthesize size;  
 7   
 8 -(id) initWithFrame: (CGRect)frame {  
 9     if ((self = [super initWithFrame:frame])) {  
10         //变量初始化  
11         redValue = 0.0f;  
12         greenValue = 0.50f;  
13         blueValue = 1.0f;  
14         size=20.0f;  
15     }  
16     return self;  
17 }  
18   
19 //重写UILable类的drawTextInRect方法  
20 -(void) drawTextInRect: (CGRect)rect {  
21     //定义阴影区域  
22     CGSize textShadowOffest = CGSizeMake(0, 0);  
23     //定义RGB颜色值  
24     float textColorValues[] = {redValue, greenValue, blueValue, 1.0};  
25       
26     //获取绘制上下文  
27     CGContextRef ctx = UIGraphicsGetCurrentContext();  
28     //保存上下文状态  
29     CGContextSaveGState(ctx);  
30       
31     //为上下文设置阴影  
32     CGContextSetShadow(ctx, textShadowOffest, size);  
33     //设置颜色类型  
34     CGColorSpaceRef textColorSpace = CGColorSpaceCreateDeviceRGB();  
35     //根据颜色类型和颜色值创建CGColorRef颜色  
36     CGColorRef textColor = CGColorCreate(textColorSpace, textColorValues);  
37     //为上下文阴影设置颜色,阴影颜色,阴影大小  
38     CGContextSetShadowWithColor(ctx, textShadowOffest, size, textColor);  
39       
40     [super drawTextInRect:rect];  
41       
42     //释放  
43     CGColorRelease(textColor);  
44     CGColorSpaceRelease(textColorSpace);  
45       
46     //重启上下文  
47     CGContextRestoreGState(ctx);  
48 }  
49   
50 @end

转载于:https://www.cnblogs.com/tryingx/articles/3721919.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
闪烁的文字,多种闪烁效果 https://github.com/Zws-China/WSShiningLabel WSShiningLabel *label1 = [[WSShiningLabel alloc] init]; label1.frame = CGRectMake(50, 35, 200, 25); label1.text = @"当保护你的她"; label1.textColor = [UIColor grayColor]; label1.font = [UIFont systemFontOfSize:20]; [label1 startShimmer]; // 开启闪烁 [self.view addSubview:label1]; WSShiningLabel *label2 = [[WSShiningLabel alloc] init]; label2.frame = CGRectMake(50, 105, 200, 25); label2.text = @"变成要你保护的她"; label2.textColor = [UIColor grayColor]; label2.font = [UIFont systemFontOfSize:20]; label2.shimmerType = ST_RightToLeft; // 滚动方向 right to left label2.durationTime = 1; // 滚动时间 label2.shimmerColor = [UIColor orangeColor]; // 高亮颜色 [label2 startShimmer]; // 开启闪烁 [self.view addSubview:label2]; WSShiningLabel *label3 = [[WSShiningLabel alloc] init]; label3.frame = CGRectMake(50, 175, 200, 25); label3.text = @"当你远离了家"; label3.textColor = [UIColor grayColor]; label3.font = [UIFont systemFontOfSize:20]; label3.shimmerType = ST_AutoReverse; // 滚动方向 左右来回 label3.shimmerWidth = 20; // 高亮的宽度 label3.shimmerRadius = 20; // 阴影的宽度 label3.shimmerColor = [UIColor yellowColor]; // 高亮颜色 [label3 startShimmer]; // 开启闪烁 [self.view addSubview:label3]; WSShiningLabel *label4 = [[WSShiningLabel alloc] init]; label4.frame = CGRectMake(50, 245, 200, 25); label4.text = @"努力有了你爱的她"; label4.textColor = [UIColor grayColor]; label4.font = [UIFont systemFontOfSize:20]; label4.shimmerType = ST_ShimmerAll; // 闪烁 label4.durationTime = 0.8; label4.shimmerColor = [UIColor redColor]; [label4 startShimmer]; [self.view addSubview:label4];
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值