OCiOS开发:CAGradientLayer 渐变色

CAGradientLayer 简介

  • CAGradientLayer是CALayer图层类的子类,用于处理渐变色的层结构。
  • CAGradientLayer的渐变色可以做隐式动画。
  • CAGradientLayer和CAShapeLayer配合使用可实现复杂效果。
  • CAGradientLayer可以用作PNG的遮罩效果。

CAGradientLayer 坐标系统

  • CAGradientLayer的坐标系统是从坐标(0,0)到(1,1)绘制的矩形。
  • CAGradientLayer的frame值的size不为正方形的话,坐标系统会被拉伸。
  • CAGradientLayer的startPoint与endPoint会直接影响颜色的绘制方向。
  • CAGradientLayer的颜色分割点是以0~1的比例来计算的,颜色分割点为渐变色开始或终止的地方。

CAGradientLayer 属性介绍

  • colors:渐变颜色数组
  • locations:渐变颜色的区间分布(分割点),locations的数组长度和colors一致。这个属性可不设,默认是nil,系统会平均分布颜色如果有特定需要可设置,数组设置为0 ~ 1之间单调递增。
  • startPoint:映射locations中起始位置,用单位向量表示。比如(0, 0)表示从左上角开始变化。默认值是:(0.5, 0.0)。
  • endPoint:映射locations中结束位置,用单位向量表示。比如(1, 1)表示到右下角变化结束。默认值是:(0.5, 1.0)。
  • type:默认值是kCAGradientLayerAxial,表示按像素均匀变化。

CAGradientLayer 案例

三原色渐变

  • 效果展示
  • 代码示例

- (void)viewDidLoad {

[super viewDidLoad];

/**< 初始化colorsView */

UIView *colorsView = [[UIView alloc] init];

colorsView.bounds = CGRectMake(0, 0, 220, 220);

colorsView.center = self.view.center;

[self.view addSubview:colorsView];

/**< 初始化渐变层 */

CAGradientLayer *gradientColorLayer = [CAGradientLayer layer];

gradientColorLayer.frame = colorsView.bounds;

[colorsView.layer addSublayer:gradientColorLayer];

/**< 设置颜色组 */

gradientColorLayer.colors = @[(__bridge id)[UIColor redColor].CGColor,

(__bridge id)[UIColor greenColor].CGColor,

(__bridge id)[UIColor blueColor].CGColor];

/**< 设置颜色分割点 */

gradientColorLayer.locations  = @[@(0.25), @(0.5), @(0.75)];

/**< 设置渐变颜色方向 */

// 1、起始位置

gradientColorLayer.startPoint = CGPointMake(0, 0);

// 2、结束位置

gradientColorLayer.endPoint   = CGPointMake(0, 1);

}

  • 分割点动画
  • 效果展示
  • 代码示例

#import "ViewController.h"

@interface ViewController ()

@property (strong, nonatomic) CAGradientLayer *gradientLayer;

@end

@implementation ViewController

- (void)viewDidLoad {

[super viewDidLoad];

// 添加 CAGradientLayer

[self.view.layer addSublayer:self.gradientLayer];

// 延时3秒执行,实现分割点动画(隐式动画)

dispatch_after(dispatch_time(DISPATCH_TIME_NOW, (int64_t)(4.0 * NSEC_PER_SEC)), dispatch_get_main_queue(), ^{

// 颜色分割点效果

self.gradientLayer.locations = @[@(0.4), @(0.5), @(0.6)];

});

}

#pragma mark - Getter methods

- (CAGradientLayer *)gradientLayer {

if (!_gradientLayer) {

// 初始化并创建

_gradientLayer             = [CAGradientLayer layer];

_gradientLayer.frame       = CGRectMake(0, 0, 250, 250);

_gradientLayer.position    = self.view.center;

_gradientLayer.borderWidth = 1.f;

// 设置颜色

_gradientLayer.colors = @[(__bridge id)[UIColor redColor].CGColor,

(__bridge id)[UIColor greenColor].CGColor,

(__bridge id)[UIColor blueColor].CGColor];

// 设置颜色渐变方向

_gradientLayer.startPoint = CGPointMake(0, 0);

_gradientLayer.endPoint   = CGPointMake(1, 0);

// 设置颜色分割点

_gradientLayer.locations  = @[@(0.25), @(0.5), @(0.75)];

}

return _gradientLayer;

}

@end

色差动画

  • 实现思路
    • 确定渐变色渐变方向;
    • 至少设定两种颜色,此处设置两种颜色为例,其中一种是透明色,另外一种是自定义颜色。
    • 设定好locations颜色分割点。
  • 效果展示
  • 代码示例

#import "ViewController.h"

@interface ViewController () {

NSTimer *_timer; /**< 定时器 */

}

@property (strong, nonatomic) CAGradientLayer *gradientLayer; /**< 渐变层 */

@end

@implementation ViewController

- (void)viewDidLoad {

[super viewDidLoad];

self.view.backgroundColor = [UIColor blackColor];

// 创建背景图片

UIImageView *imageView = [[UIImageView alloc] initWithImage:[UIImage imageNamed:@"image"]];

imageView.bounds       = CGRectMake(0, 0, 260, 450);

imageView.center       = self.view.center;

[self.view addSubview:imageView];

// 添加渐变层

[imageView.layer addSublayer:self.gradientLayer];

// 初始化定时器

_timer = [NSTimer scheduledTimerWithTimeInterval:1.f

target:self

selector:@selector(respondsToTimerEvent)

userInfo:nil

repeats:YES];

}

#pragma mark - Timer and animations methods

- (void)respondsToTimerEvent {

// 设定颜色组动画

self.gradientLayer.colors = @[(__bridge id)[UIColor clearColor].CGColor,

(__bridge id)[UIColor colorWithRed:arc4random()%255 / 255.f

green:arc4random()%255 / 255.f

blue:arc4random()%255 / 255.f

alpha:1].CGColor];

// 设置颜色分割点动画

self.gradientLayer.locations = @[@(arc4random() %10 / 10.f), @(1.f)];

}

#pragma mark - Getter methods

- (CAGradientLayer *)gradientLayer {

if (!_gradientLayer) {

// 初始化渐变层

_gradientLayer       = [CAGradientLayer layer];

_gradientLayer.frame = CGRectMake(0, 0, 260, 450);

// 设置颜色渐变方向

_gradientLayer.startPoint = CGPointMake(0, 0);

_gradientLayer.endPoint   = CGPointMake(0, 1);

// 设定颜色组

_gradientLayer.colors = @[(__bridge id)[UIColor clearColor].CGColor,

(__bridge id)[UIColor blueColor].CGColor];

// 设定颜色分割点

_gradientLayer.locations = @[@(0.5f), @(1.f)];

}

return _gradientLayer;

}

@end

OCiOS开发:CAGradientLayer 渐变色的更多相关文章

  1. OCiOS开发:音频播放器 AVAudioPlayer

    简单介绍 AVAudioPlayer音频播放器可以提供简单的音频播放功能.其头文件包括在AVFoudation.framework中. AVAudioPlayer未提供可视化界面,须要通过其提供的播放 ...

  2. swift - layer - 渐变色 - CAGradientLayer

    1.创建 渐变色 /// 渐变色:默认从上到下 private var gradientLayer: CAGradientLayer = { let g = CAGradientLayer() g.c ...

  3. Coding源码学习第三部分(EaseStartView.m)

    首先接上篇的要做一个NSEnumerator 类的延展阅读. 枚举(NSEnumerator) (1)依附于集合类(NSArray,NSSet,NSDictionary),没有用来创建实例的接口. ( ...

  4. My English Dictionary

    A axis 坐标轴 architecture 结构 B C consider 考虑 closure  闭包 clip  修剪 convert 改变 D default 默认的 valid 有效的 d ...

  5. 【iOS系列】-使用CAGradientLayer设置渐变色

    有时候iOS开发中需要使用到渐变色,来给图片或者view盖上一层,使其显示效果更好,我们这里使用的CAGradientLayer来设置渐变色 要实现的效果如下: Demo地址---下载 // 创建渐变 ...

  6. 通过CAGradientLayer制作渐变色效果(转)

    转载自:http://blog.it985.com/7986.html 看了极客学院的视频之后写的一篇博客,觉得不错,还是作为笔记使用. 简单介绍一下CAGradientLayer吧. Gradien ...

  7. 用CAGradientLayer实现渐变色动画

    效果图: github:https://github.com/RinpeChen/CAGradientLayerBasicDemo

  8. iOS - 开发类库

    开发类库   UI 项目名称 项目信息 1.MJRefresh 仅需一行代码就可以为UITableView或者CollectionView加上下拉刷新或者上拉刷新功能.可以自定义上下拉刷新的文字说明. ...

  9. iOS:iOS开发非常全的三方库、插件等等

    iOS开发非常全的三方库.插件等等 github排名:https://github.com/trending, github搜索:https://github.com/search. 此文章转自git ...

随机推荐

  1. ThreadPoolExecutor(下篇)

    上篇写到了ThreadPoolExecutor构造方法前4个参数int corePoolSize.int maximumPoolSize,.long keepAliveTime.TimeUnit un ...

  2. hdu 3255 体积并

    http://www.cnblogs.com/kane0526/archive/2013/03/07/2948446.html http://blog.csdn.net/acdreamers/arti ...

  3. echarts环形图点击旋转并高亮

    通过计算某个扇形区域的值占整个圆的百分比来得到这个扇形的角度,从而根据startAngle这个属性来设定图形的开始渲染的角度,使点击某个扇形时圆环旋转使之始终对准某个点. 期间考虑到某扇形区域太小点击 ...

  4. Linux服务器性能评估与优化(二)

    网络内容总结(感谢原创) 1.Linux内核参数优化 内核参数是用户和系统内核之间交互的一个接口,通过这个接口,用户可以在系统运行的同时动态更新内核配置,而这些内核参数是通过Linux Proc文件系 ...

  5. 从虚拟机角度看Java多态->(重写override)的实现原理

    工具与环境:Windows 7 x64企业版Cygwin x64jdk1.8.0_162 openjdk-8u40-src-b25-10_feb_2015Vs2010 professional 0x0 ...

  6. 使用版本 1.0.0 的 Azure ARM SDK for Java 创建虚拟机时报错

    问题描述 我们可以通过使用 Azure ARM SDK 来管理 Azure 上的资源,因此我们也可以通过 SDK 来创建 ARM 类型的虚拟机,当我们使用 1.0.0 版本的 Azure SDK fo ...

  7. mysql导入导出csv

    LOAD DATA local INFILE '/tmp/stb.csv' INTO TABLE stb FIELDS TERMINATED BY ',' enclosed by '"' l ...

  8. shell定时采集数据到HDFS

    上线的网站每天都会产生日志数据.假如有这样的需求:要求在凌晨 24 点开始操作前一天产生的日志文件,准实时上传至 HDFS 集群上. 该如何实现?实现后能否实现周期性上传需求?如何定时? Linux ...

  9. C# 调用 SQL server 初探

    相信不少人都和我一样: 1.学过数据库原理接触过SQL Server,做过一套卷子外加一个数据库设计作业: 2.学过C# 但从来还没在程序里用到过数据库(哈哈,新手躺枪) 这也是我第一次在C#里用数据 ...

  10. OAuth 2.0协议在SAP产品中的应用

    阮一峰老师曾经在他的博文理解OAuth 2.0里对这个概念有了深入浅出的阐述. http://www.ruanyifeng.com/blog/2014/05/oauth_2_0.html 本文会结合我 ...