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
    评论
### 回答1: 可以使用以下代码来实现 iOS 按钮的背景渐变色:CAGradientLayer *gradient = [CAGradientLayer layer]; gradient.frame = self.btn.bounds; gradient.colors = [NSArray arrayWithObjects:(id)[[UIColor whiteColor] CGColor], (id)[[UIColor blackColor] CGColor], nil]; [self.btn.layer insertSublayer:gradient atIndex:0]; ### 回答2: iOS按钮背景渐变色可以通过以下步骤使用OC代码实现: 1. 导入渐变色所需的头文件: ```objc #import <QuartzCore/QuartzCore.h> ``` 2. 创建按钮: ```objc UIButton *myButton = [[UIButton alloc] initWithFrame:CGRectMake(50, 50, 200, 50)]; [self.view addSubview:myButton]; ``` 3. 创建渐变色图层: ```objc CAGradientLayer *gradient = [CAGradientLayer layer]; gradient.frame = myButton.bounds; ``` 4. 设置渐变色图层的颜色: ```objc gradient.colors = @[(id)[UIColor redColor].CGColor, (id)[UIColor blueColor].CGColor]; ``` 5. 设置渐变色方向: ```objc // 横向渐变 gradient.startPoint = CGPointMake(0, 0.5); gradient.endPoint = CGPointMake(1, 0.5); // 纵向渐变 // gradient.startPoint = CGPointMake(0.5, 0); // gradient.endPoint = CGPointMake(0.5, 1); ``` 6. 将渐变色图层添加到按钮的背景图层: ```objc [myButton.layer insertSublayer:gradient atIndex:0]; ``` 7. 最后,可以给按钮设置一些其他属性,如标题、字体等: ```objc [myButton setTitle:@"渐变按钮" forState:UIControlStateNormal]; [myButton.titleLabel setFont:[UIFont systemFontOfSize:17]]; [myButton setTitleColor:[UIColor whiteColor] forState:UIControlStateNormal]; ``` 通过以上步骤,即可通过OC代码实现iOS按钮的背景渐变色效果。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值