【code_小马】iOS CAGradientLayer绘制渐变色

我们是工程师 ——加油 !

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岁以后,在童年和少年的分界线上,我就没再和外人亲近过,我的世界里只有如风,他也一样。而现在,在他那边真的多了一个人吗?所以那天他才会莫名其妙的发了一顿脾气?    整整一天我都混混沌沌的,晚上下起了雨,如风迟迟没有回来。平时他也有收工晚的时候,我都是在家等他的,可今天我却坐不住了,心里很不安。我知道阿珊的话让我震动了,我不愿意看见如风身边站着任何一个旁人。.............................

点击阅读文章第七集

点击阅读文章第九集

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 194,911评论 5 460
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 82,014评论 2 371
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 142,129评论 0 320
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 52,283评论 1 264
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 61,159评论 4 357
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 46,161评论 1 272
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 36,565评论 3 382
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 35,251评论 0 253
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 39,531评论 1 292
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 34,619评论 2 310
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 36,383评论 1 326
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 32,255评论 3 313
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 37,624评论 3 299
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 28,916评论 0 17
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 30,199评论 1 250
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 41,553评论 2 342
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 40,756评论 2 335

推荐阅读更多精彩内容

  • 今天,我坐在这里,距离我第一次见到他的时候整整20年了。然而,我闭上眼睛仿佛还能见到那个满身雨水的小男孩怔怔的看着...
    信箱77阅读 1,240评论 2 21
  • 我对儿童节一向没什么好感,在幼儿园时的儿童节至今记忆犹新,当年我和哥哥就读父亲单位的幼儿园,正是计划生育抓的...
    酷雪冰凌阅读 279评论 8 5
  • 花开了吗 何处钟声 谁在山空呜咽 竹箫的低吟 日出了吗 何处岚影 谁在天上落笔 叶间的晕染 风来了吗 何处筱影 谁...
    茗香酒影阅读 148评论 0 1
  • 文/旧时安 -1- 赵村从来没下过这么大的雨,黄豆大小的雨一下就是整整一周。大雨导致河水猛涨,河边赵老四家的玉米全...
    麓安安阅读 1,733评论 25 66
  • 每日必读:12条人生原则 1. 早睡早起——晚不超过22:30,早不晚于6:00,醒后不睡回笼觉。 2. 谨言——...
    衡山阅读 209评论 1 0