iOS开发CoreAnimation解读之三——几种常用Layer的使用解析

本文涉及的产品
云解析 DNS,旗舰版 1个月
全局流量管理 GTM,标准版 1个月
公共DNS(含HTTPDNS解析),每月1000万次HTTP解析
简介:

iOS开发CoreAnimation解读之三——几种常用Layer的使用解析

一、CAEmitterLayer

        CAEmitterLayer是CoreAnimation框架中的粒子发射层,在以前的一片博客中有详细的介绍和范例,这里不再重复,地址如下:

粒子效果的应用和火焰范例:http://my.oschina.net/u/2340880/blog/485095

二、CAGradientLayer

        CAGradientLayer是用于色彩梯度展示的layer图层,通过CAGradientLayer,我们可以很轻松的创建出有过渡效果的色彩图。其中属性如下:

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
/*
颜色数组,设置我们需要过的的颜色,必须是CGColor对象
*/
@property(nullable, copy) NSArray *colors;
/*
颜色开始进行过渡的位置
这个数组中的元素是NSNumber类型,单调递增的,并且在0——1之间
例如,如果我们设置两个颜色进行过渡,这个数组中写入0.5,则第一个颜色会在达到layer一半的时候开始向第二个颜色过渡
*/
@property(nullable, copy) NSArray<NSNumber *> *locations;
/*
下面两个参数用于设置渲染颜色的起点和终点 取值范围均为0——1
默认起点为(0.5 ,0) 终点为(0.5 ,1),颜色的过渡范围就是沿y轴从上向下
*/
@property CGPoint startPoint;
@property CGPoint endPoint;
/*
渲染风格 iOS中只支持一种默认的kCAGradientLayerAxial,我们无需手动设置
*/
@property(copy) NSString *type;

用如下代码创建一个度过视图的效果:

?
1
2
3
4
5
6
7
8
     CAGradientLayer * layer = [CAGradientLayer layer];
     layer.colors = @[(id)[UIColor redColor].CGColor,(id)[UIColor blueColor].CGColor,(id)[UIColor greenColor].CGColor];
     layer.locations = @[@0.1,@0.7,@1];
     layer.bounds = CGRectMake(0, 0, 100, 100);
     layer.position = CGPointMake(100, 100);
     layer.startPoint = CGPointMake(0, 0);
     layer.endPoint = CGPointMake(1, 1);
     [self.view.layer addSublayer:layer];

效果如下:

三、CAReplicatorLayer

        CAReplocatorLayer是拷贝视图容器,我们可以通过它,将其中的子layer进行拷贝,并进行一些差异处理,其中常用属性方法如下:

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
//拷贝的次数
@property NSInteger instanceCount;
//是否开启景深效果
@property  BOOL  preservesDepth;
//当CAReplicatorLayer的子Layer层进行动画的时候,拷贝的副本执行动画的延时
@property CFTimeInterval instanceDelay;
//拷贝副本的3D变换
@property CATransform3D instanceTransform;
//拷贝副本的颜色变换
@property(nullable) CGColorRef instanceColor;
//每个拷贝副本的颜色偏移参数
@property  float  instanceRedOffset;
@property  float  instanceGreenOffset;
@property  float  instanceBlueOffset;
//每个拷贝副本的透明度偏移参数
@property  float  instanceAlphaOffset;

例如,通过拷贝一个色块,使其产生平移排列:

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
     CAReplicatorLayer *reLayer = [CAReplicatorLayer layer];
     reLayer.position = CGPointMake(0, 0);
     CALayer * layer= [CALayer layer];
     [reLayer addSublayer:layer];
     [self.view.layer addSublayer:reLayer];
     layer.bounds = CGRectMake(0, 0, 20, 20);
     layer.position = CGPointMake(30, 100);
     layer.backgroundColor = [UIColor redColor].CGColor;
     //每个副本向右平移25px
     reLayer.instanceTransform=CATransform3DMakeTranslation(25, 0, 0);
     //如果进行动画,副本延时一秒执行
     reLayer.instanceDelay = 1;
     //拷贝十个副本
     reLayer.instanceCount = 10;

效果如下:

四、CAShapeLayer

        CAShapeLayer是图形layer层,我们可以自定义这个层的形状。先来看其中我们可以使用的属性和方法:

?
1
@property(nullable) CGPathRef path;

path属性为CAShapeLayer设置一个边界路径,例如我们可以创建一个三角形的路径通过如下代码:

?
1
2
3
4
5
6
7
8
     CAShapeLayer * layer = [CAShapeLayer layer];
     layer.position=CGPointMake(0,0);
     CGMutablePathRef path = CGPathCreateMutable();
     CGPathMoveToPoint(path, 0, 100, 100);
     CGPathAddLineToPoint(path, 0, 300, 100);
     CGPathAddLineToPoint(path, 0, 200, 200);
     CGPathAddLineToPoint(path, 0, 100, 100);
     layer.path=path;

仅仅有路径,不能将我们想要的形状画出来,下面一些属性可以对图形的一些基础属性进行设置:

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
//设置图形的填充颜色
@property(nullable) CGColorRef fillColor;
/*
设置图形的填充规则 选项如下:
非零填充
  NSString *const kCAFillRuleNonZero;
  奇偶填充
  NSString *const kCAFillRuleEvenOdd;
*/
@property(copy) NSString *fillRule;
//设置线条颜色
@property(nullable) CGColorRef strokeColor;
//设置线条的起点与终点 0-1之间
@property CGFloat strokeStart;
@property CGFloat strokeEnd;
//设置线条宽度
@property CGFloat lineWidth;
//设置两条线段相交时锐角斜面长度
@property CGFloat miterLimit;
/*
设置线条首尾的外观
可选参数如下
无形状
  NSString *const kCALineCapButt;
  圆形
  NSString *const kCALineCapRound;
  方形
  NSString *const kCALineCapSquare;
*/
@property(copy) NSString *lineCap;
/*
设置线段的链接方式
棱角
  NSString *const kCALineJoinMiter;
  平滑
  NSString *const kCALineJoinRound;
  折线
  NSString *const kCALineJoinBevel;
*/
@property(copy) NSString *lineJoin;

修改一下上面的代码,如下:

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
CAShapeLayer * layer = [CAShapeLayer layer];
     layer.position=CGPointMake(0,0);
     CGMutablePathRef path = CGPathCreateMutable();
     CGPathMoveToPoint(path, 0, 100, 100);
     CGPathAddLineToPoint(path, 0, 300, 100);
     CGPathAddLineToPoint(path, 0, 200, 200);
     CGPathAddLineToPoint(path, 0, 100, 100);
     layer.path=path;
     layer.fillColor= [UIColor redColor].CGColor;
     layer.fillRule = kCAFillRuleEvenOdd;
     layer.strokeColor = [UIColor blueColor].CGColor;
     layer.strokeStart =0;
     layer.strokeEnd =0.5;
     layer.lineWidth = 5;
     layer.miterLimit = 1;
     layer.lineJoin = kCALineJoinMiter;
     [self.view.layer addSublayer:layer];

效果如下:

除此之外,我们还可以设置边界的线条为虚线,通过下面两个属性:

?
1
2
3
4
5
6
7
     //设置线段的宽度为5px 间距为10px
     /*
     这个数组中还可以继续添加,会循环进行设置 例如 5 2 1 3 则第一条线段5px,间距2px,第二条线段1px 间距3px再开始第一条线段
     */
     layer.lineDashPattern = @[@05,@10];
     //设置从哪个位置开始
     layer.lineDashPhase =5;

如下:

五、CATextLayer

        CATextLayer可以进行文本的绘制,属性方法如下:

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
//渲染的文字字符串
@property(nullable, copy) id string;
//设置字体
@property(nullable) CFTypeRef font;
//设置字号
@property CGFloat fontSize;
//设置文字颜色
@property(nullable) CGColorRef foregroundColor;
//是否换行
@property(getter=isWrapped)  BOOL  wrapped;
/*
设置截断模式
  NSString * const kCATruncationNone;
  截断前部分
  NSString * const kCATruncationStart;
  截断后部分
  NSString * const kCATruncationEnd;
  截断中间
  NSString * const kCATruncationMiddle;
*/
@property(copy) NSString *truncationMode;
/*
设置文字对齐模式
  NSString * const kCAAlignmentNatural;
  NSString * const kCAAlignmentLeft;
  NSString * const kCAAlignmentRight;
  NSString * const kCAAlignmentCenter;
  NSString * const kCAAlignmentJustified;
*/
@property(copy) NSString *alignmentMode;

目录
相关文章
|
3天前
|
设计模式 前端开发 Swift
探索iOS开发:从初级到高级的旅程
【10月更文挑战第31天】在这篇文章中,我们将一起踏上iOS开发的旅程。无论你是初学者还是有经验的开发者,这篇文章都将为你提供有价值的信息和技巧。我们将从基础开始,逐步深入到更高级的技术和概念。让我们一起探索iOS开发的世界吧!
|
6天前
|
设计模式 前端开发 Swift
探索iOS开发:从初级到高级的旅程
【10月更文挑战第28天】在这篇技术性文章中,我们将一起踏上一段探索iOS开发的旅程。无论你是刚入门的新手,还是希望提升技能的开发者,这篇文章都将为你提供宝贵的指导和灵感。我们将从基础概念开始,逐步深入到高级主题,如设计模式、性能优化等。通过阅读这篇文章,你将获得一个清晰的学习路径,帮助你在iOS开发领域不断成长。
31 2
|
2天前
|
存储 数据可视化 Swift
探索iOS开发之旅:从新手到专家
【10月更文挑战第33天】在这篇文章中,我们将一起踏上一场激动人心的iOS开发之旅。无论你是刚刚入门的新手,还是已经有一定经验的开发者,这篇文章都将为你提供宝贵的知识和技能。我们将从基础的iOS开发概念开始,逐步深入到更复杂的主题,如用户界面设计、数据存储和网络编程等。通过阅读这篇文章,你将获得成为一名优秀iOS开发者所需的全面技能和知识。让我们一起开始吧!
|
3天前
|
移动开发 Java Android开发
探索Android与iOS开发的差异性与互联性
【10月更文挑战第32天】在移动开发的大潮中,Android和iOS两大平台各领风骚。本文将深入浅出地探讨这两个平台的开发差异,并通过实际代码示例,展示如何在各自平台上实现相似的功能。我们将从开发环境、编程语言、用户界面设计、性能优化等多个角度进行对比分析,旨在为开发者提供跨平台开发的实用指南。
20 0
|
10天前
|
安全 5G Android开发
安卓与iOS的较量:技术深度解析
【10月更文挑战第24天】 在移动操作系统领域,安卓和iOS无疑是两大巨头。本文将深入探讨这两个系统的技术特点、优势和不足,以及它们在未来可能的发展方向。我们将通过对比分析,帮助读者更好地理解这两个系统的本质和内涵,从而引发对移动操作系统未来发展的深思。
20 0
|
28天前
|
缓存 Java 程序员
Map - LinkedHashSet&Map源码解析
Map - LinkedHashSet&Map源码解析
62 0
|
28天前
|
算法 Java 容器
Map - HashSet & HashMap 源码解析
Map - HashSet & HashMap 源码解析
49 0
|
28天前
|
存储 Java C++
Collection-PriorityQueue源码解析
Collection-PriorityQueue源码解析
58 0
|
28天前
|
安全 Java 程序员
Collection-Stack&Queue源码解析
Collection-Stack&Queue源码解析
72 0
|
8天前
|
消息中间件 缓存 安全
Future与FutureTask源码解析,接口阻塞问题及解决方案
【11月更文挑战第5天】在Java开发中,多线程编程是提高系统并发性能和资源利用率的重要手段。然而,多线程编程也带来了诸如线程安全、死锁、接口阻塞等一系列复杂问题。本文将深度剖析多线程优化技巧、Future与FutureTask的源码、接口阻塞问题及解决方案,并通过具体业务场景和Java代码示例进行实战演示。
27 3

推荐镜像

更多