iOS中制作渐变色视图

在iOS中,学会使用渐变色来设置一个视图的颜色比用图片要好一些。

可以到guithb上下载CRGradientLabel类来做需要的UILabel,我把该类的继承UILabel改为了UIVIew,这样就可以把任意的VIew的颜色设置为渐变色了。

文件:

CRGradientLabel.h

#import <UIKit/UIKit.h>


@interface CRGradientLabel :UIView


@property (nonatomic,strong) NSArray *gradientColors;


@end



CRGradientLabel.m文件

#import "CRGradientLabel.h"


@import CoreGraphics;


@interface CRGradientLabel ()


@end


@implementation CRGradientLabel


- (id)initWithFrame:(CGRect)frame

{

    self = [superinitWithFrame:frame];

    if (self) {

        // Initialization code

    }

    returnself;

}


- (void)drawRect:(CGRect)rect

{

    CGContextRef context =UIGraphicsGetCurrentContext();

    

    NSMutableArray *colors = [NSMutableArrayarrayWithCapacity:[self.gradientColorscount]];

    [self.gradientColorsenumerateObjectsUsingBlock:^(id obj,NSUInteger idx, BOOL *stop) {

        if ([objisKindOfClass:[UIColorclass]]) {

            [colors addObject:(__bridgeid)[obj CGColor]];

        } elseif (CFGetTypeID((__bridgevoid *)obj) == CGColorGetTypeID()) {

            [colors addObject:obj];

        } else {

            @throw [NSExceptionexceptionWithName:@"CRGradientLabelError"

                                           reason:@"Object in gradientColors array is not a UIColor or CGColorRef"

                                         userInfo:NULL];

        }

    }];

    

    CGContextSaveGState(context);

    CGContextScaleCTM(context,1.0, -1.0);

    CGContextTranslateCTM(context,0, -rect.size.height);

    

    CGGradientRef gradient =CGGradientCreateWithColors(NULL, (__bridgeCFArrayRef)colors, NULL);

    

    CGPoint startPoint =CGPointMake(CGRectGetMidX(rect),CGRectGetMinY(rect));

    CGPoint endPoint =CGPointMake(CGRectGetMidX(rect),CGRectGetMaxY(rect));

    

    CGContextDrawLinearGradient(context, gradient, startPoint, endPoint,

                                kCGGradientDrawsAfterEndLocation |kCGGradientDrawsBeforeStartLocation);

    

    CGGradientRelease(gradient);

    CGContextRestoreGState(context);

    

    [superdrawRect: rect];

}


@end


效果图:



使用的例子:

.m 文件:

导入CRGradientLabel头文件


#import "ViewController.h"

#import "CRGradientLabel.h"


@interface ViewController ()

@end


@implementation ViewController


- (void)viewDidLoad {

    [superviewDidLoad];

    CRGradientLabel * view = [[CRGradientLabelalloc] initWithFrame:

CGRectMake(20,64,345,500)];

    view.gradientColors =@[[UIColorcolorWithRed:239/255.0fgreen:77/255.0fblue:182/255.0falpha:1.0f], [UIColorcolorWithRed:198/255.0fgreen:67/255.0fblue:252/255.0falpha:1.0f]];  //该数组存放渐变色

    [self.viewaddSubview:view];

    

}



@end







  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值