美文网首页iOS开发iOS Developer
【code_小马】CAGradientLayer绘制渐变色

【code_小马】CAGradientLayer绘制渐变色

作者: 曾经像素有点低 | 来源:发表于2017-02-24 11:26 被阅读15322次
    我们是工程师 ——加油 !

    CALayer篇:

    再废话一句:本文中一共提供了两个方向上变色的绘制方法(水平方向,对角线方向)

    屏幕快照 2017-02-24 上午11.21.21.png
    /** 不多说,直接撸代码*/
    
    
    #import "ViewController.h"
    #define YG_SCREEN_WIDTH     [UIScreen mainScreen].bounds.size.width
    #define YG_SCREEN_HEIGHT    [UIScreen mainScreen].bounds.size.height
    
    
    @interface ViewController ()
    
    /**计时器*/
    @property (nonatomic, strong) NSTimer  *timer;
    /**顶部进度条*/
    @property (nonatomic,strong) CAGradientLayer * YG_top_colorLayer;
    
    @end
    
    @implementation ViewController
    
    - (void)viewDidLoad {
        [super viewDidLoad];
        
        self.view.backgroundColor           = [UIColor blackColor];
    
        /**创建顶部进度条--水平防线颜色渐变*/
        [self creatYGTopColorLayer];
        /**创建底部彩带--对角线方向颜色渐变*/
        [self creatYGBottomColorLayer];
        
        /**添加一个标签*/
        [self creatMyLabel];     //这一句基本没用,哈哈哈
        
    }
    
    
    • 实现方法
    #pragma mark -- 创建顶部 水平方向变色的进度条
    -(void)creatYGTopColorLayer
    {
        /**创建*/
        self.self.YG_top_colorLayer     = [CAGradientLayer layer];
        /**设置frame*/
        self.YG_top_colorLayer.frame                 = (CGRect){CGPointMake(0, 64), CGSizeMake(15, 3)};
        
        /**修改位置为屏幕居中*/
        //    self.YG_top_colorLayer.position              = self.view.center;
        /**添加到View上*/
        [self.view.layer addSublayer:self.YG_top_colorLayer];
        
        /**颜色分配----类型(NSArray)*/
        self.YG_top_colorLayer.colors                = @[(__bridge id)[UIColor redColor].CGColor,
                                                    (__bridge id)[UIColor blueColor].CGColor,
                                                    (__bridge id)[UIColor greenColor].CGColor,
                                                    (__bridge id)[UIColor yellowColor].CGColor];
        
        /**颜色分割线----类型(NSArray<NSNumber *>)*/
        self.YG_top_colorLayer.locations             = @[@(0.2),@(0.4),@(0.6),@(0.8)];
        
        /**起始点----类型:(CGPoint)*/
        self.YG_top_colorLayer.startPoint            = CGPointMake(0, 0);
        
        /**结束点----类型:(CGPoint)*/
        self.YG_top_colorLayer.endPoint              = CGPointMake(1, 0);
        
        
        self.timer = [NSTimer scheduledTimerWithTimeInterval:0.3f
                                                     target:self
                                                   selector:@selector(TimerEvent)
                                                   userInfo:nil
                                                    repeats:YES];
    }
    
    
    • 简单实现计时器的方法,实际开放中要根据下载进度或者需求去设置
    
    #pragma mark - 定时器响应事件
    
    - (void)TimerEvent
    {
        //定时改变颜色(后边两个效果图,第一个是注释掉了这行代码这个行的,第二个是没有注释的);
        self.YG_top_colorLayer.colors = @[(__bridge id)[UIColor redColor].CGColor,
                                          (__bridge id)[UIColor blueColor].CGColor,
                                          (__bridge id)[UIColor greenColor].CGColor,
                                          (__bridge id)[UIColor colorWithRed:arc4random() % 255 / 255.0
                                                                       green:arc4random() % 255 / 255.0
                                                                        blue:arc4random() % 255 / 255.0
                                                                       alpha:1.0].CGColor];
        
        //定时改变分割点
        self.YG_top_colorLayer.locations = @[@(arc4random() % 2 / 10.0f),           //取0.0~0.2之间的数值
                                             @(arc4random() % 4 / 10.0f + 0.21f),   //取0.21~0.4之间的数值
                                             @(arc4random() % 6 / 10.0f + 0.41f),   //取0.41~0.6之间的数值
                                             @(arc4random() % 8 / 10.0f + 0.61f)];  //取0.61~0.8之间的数值
        //定时增加进度条宽度
        
        CGRect progressRect = [self.YG_top_colorLayer frame];
        if (progressRect.size.width < YG_SCREEN_WIDTH) {
            progressRect.size.width += 10;
        } else {
            progressRect.size.width = 15;
        }
        
        [self.YG_top_colorLayer setFrame:progressRect];
    }
    
    
    
    • 无颜色变化的效果


      无颜色变化的效果.gif
    • 有颜色变化的效果
    有颜色变化的效果.gif

    无奈。。gif上效果并不是很明显....而且这次没有UI设计师在配色上的指导,我的颜色好丑啊.....

    • 下边是底部那条 对角线方向上 变色 彩带的绘制方法
    #pragma mark -- 创建底部 沿对角线变色的彩带
    -(void)creatYGBottomColorLayer
    {
        /**创建*/
        CAGradientLayer * YG_bottom_colorLayer     = [CAGradientLayer layer];
        /**设置frame*/
        YG_bottom_colorLayer.frame                 = (CGRect){CGPointMake(0, YG_SCREEN_HEIGHT-164), CGSizeMake(YG_SCREEN_WIDTH, 20)};
        
        /**修改位置为屏幕居中*/
        //    YG_bottom_colorLayer.position              = self.view.center;
        /**添加到View上*/
        [self.view.layer addSublayer:YG_bottom_colorLayer];
        
       
        
        
        
        /**颜色分配----类型(NSArray)*/
        YG_bottom_colorLayer.colors                = @[(__bridge id)[UIColor redColor].CGColor,
                                                       (__bridge id)[UIColor blueColor].CGColor,
                                                       (__bridge id)[UIColor greenColor].CGColor,
                                                       (__bridge id)[UIColor yellowColor].CGColor];
        /*也可以用下面的方式创建颜色的数组
         [NSArray arrayWithObjects:
                                    (id)[[[UIColor redColor] colorWithAlphaComponent:1] CGColor],
                                    (id)[[[UIColor blueColor] colorWithAlphaComponent:1] CGColor],
                                    (id)[[[UIColor greenColor] colorWithAlphaComponent:1] CGColor],
                                    (id)[[UIColor yellowColor] CGColor],
                                    nil];
         */
        
        
        
        
        /**颜色分割线----类型(NSArray<NSNumber *>)*/
        YG_bottom_colorLayer.locations             = @[@(0.2),@(0.4),@(0.6),@(0.8)];
        
        /*也可以用下边的方式创建颜色分割线
         [NSArray arrayWithObjects:[NSNumber numberWithFloat:0.0],
         [NSNumber numberWithFloat:0.2],
         [NSNumber numberWithFloat:0.4],
         [NSNumber numberWithFloat:0.6],
         [NSNumber numberWithFloat:0.8],
         [NSNumber numberWithFloat:1.0],
         nil];
         */
        
      
        
        
        /**起始点----类型:(CGPoint)*/
        YG_bottom_colorLayer.startPoint            = CGPointMake(0, 0);
        
        /**结束点----类型:(CGPoint)*/
        YG_bottom_colorLayer.endPoint              = CGPointMake(1, 1);
        
        
    }
    
    
    • 下边这个没啥用的啊,不建议浪费时间看这个
    #pragma mark -- 添加标签
    -(void)creatMyLabel
    {
        UILabel * label = [[UILabel alloc]init];
        label.frame = CGRectMake(0, 0, 200, 30);
        label.text = @"小马儿 你到�是给我 加载啊 你!";
        label.textAlignment = NSTextAlignmentCenter;
        label.textColor = [UIColor whiteColor];
        label.center = self.view.center;
        [self.view addSubview:label];
    }
    
    

    【code_小马】

    晌午时光

    很喜欢的一篇文章,拿出来和大家分享
    【第八集】

    阿珊对于他和如风的第一次正式会面很不满意,第二天她决定抛开我直接和如风一对一。    阿珊来到了如风的工地,在阳光的照耀下赤裸着上身的如风让阿珊目眩神迷。    “如风!”阿珊喊。    如风慌忙扔下手里的沙袋跑了过来说:“什么事?我姐出了什么事么?”    “如画她没事。”阿珊说。    “哦,那我回去干活了。”如风态度顿时冷漠了下来。    阿珊一把拉住他说:“你先别走!我有事啊!”    如风挣开她的手说:“对不起,你的事跟我没关系。”    阿珊没想到他竟会如此冷漠,她从小到大还从未遭到这样的冷遇,她含着眼泪说:“你怎么这样呢!我来是想请你吃顿饭的,交个朋友不好吗?”    如风不为所动,仍旧冷漠的说:“你想和我交往是么?”    阿珊红了脸,使劲揪着裙子没有应答。    如风接着说:“你喜欢我什么呢?只是长的还好吗?我们不是一个世界的,你永远走不到我这里,所以算了吧。”    阿珊很不甘心,她说:“那我有什么不好呢?你的世界怎么了,连一个女孩都容不下吗?”    如风低下头幽幽地说:“那里有个人。”    阿珊大怒说:“说得好听,原来是有女朋友了?既然有就直说好了,这么逗人玩显得很帅吗?”    如风说:“随便你怎么说吧,总之我们不可能。”    阿珊说:“别小看人了!谁要和你在一起!”    阿珊抽泣着跑了,如风突然想起了什么,喊道:“喂!你等一下!”    阿珊以为还有余寰,站住了脚。    如风说:“别跟我姐说你来找我了。”    阿珊彻底死心,她回头喊道:“谁还会记得你!这辈子我都不会提你的名字!”    第二天上课,阿珊问我:“你弟弟有女友?”    我不明所以的说:“没有啊。”    “哼!你蒙在鼓里罢了!”阿珊说,“你这么不解风情的姐姐跟你说了也不管用!”    我默默低下头,阿珊的话就像在我心里扔了颗石头。    好像从13岁以后,在童年和少年的分界线上,我就没再和外人亲近过,我的世界里只有如风,他也一样。而现在,在他那边真的多了一个人吗?所以那天他才会莫名其妙的发了一顿脾气?    整整一天我都混混沌沌的,晚上下起了雨,如风迟迟没有回来。平时他也有收工晚的时候,我都是在家等他的,可今天我却坐不住了,心里很不安。我知道阿珊的话让我震动了,我不愿意看见如风身边站着任何一个旁人。.............................

    点击阅读文章第七集

    点击阅读文章第九集

    相关文章

      网友评论

        本文标题:【code_小马】CAGradientLayer绘制渐变色

        本文链接:https://www.haomeiwen.com/subject/limvwttx.html