关于CAShapeLayer
内容大纲:
- CAShapeLayer简介
- 贝塞尔曲线与CAShapeLayer的关系
- strokeStart和strokeEnd 动画
- 用CAShapeLayer实现进度条效果,以及更加复杂的效果
1、CAShapeLayer简介
- 1、CAShapeLayer继承自CALayer,可以使用CALayer的所有属性值
- 2、CAShapeLayer需要与贝塞尔曲线配合使用才有意义
- 3、使用CAShapeLayer与贝塞尔曲线可以实现不在view的drawRect方法中画出有一些想要的图形
- 4、CAShapeLayer属于CoreAnimation框架,其动画渲染直接提交到手机的GPU当中,相较于view的drawRect方法使用CPU渲染而言,其效率极高,能大大优化内存使用情况。
- 个人经验:可以重写UIView的子类中的drawRect来实现进度条效果,但是UIView的drawRect是用CPU渲染实现的,而使用CAShapeLayer效率更高,因为它用的是GPU渲染。
data:image/s3,"s3://crabby-images/20392/203922f65cd73d84f9ad9e9cd333eeead842db65" alt="iOS之UI--CAShapeLayer iOS之UI--CAShapeLayer"
data:image/s3,"s3://crabby-images/92106/921064d706dd19552fa63caa22635fb4760b918d" alt="iOS之UI--CAShapeLayer iOS之UI--CAShapeLayer"
data:image/s3,"s3://crabby-images/e39c9/e39c961113421704c42117c97fdb4edc5c7c1c7a" alt="iOS之UI--CAShapeLayer iOS之UI--CAShapeLayer"
效果:
data:image/s3,"s3://crabby-images/2fddf/2fddf3d81bd112493b8eff29b2b6eb6d2dc447d6" alt="iOS之UI--CAShapeLayer iOS之UI--CAShapeLayer"
虽然说,直接更改另外创建的CALayer以及其子类,会触发隐式动画,但是直接更改CAShapeLayer的path的值,变化过程没有渐变移动的效果,所以这里就需要
使用核心动画CABasicAnimation来帮忙实现,未使用核心动画验证效果在后面的"4、用CAShapeLayer实现进度条效果,以及更加复杂的效果"验证了。
2、贝塞尔曲线与CAShapeLayer的关系
- 1、CAShapeLayer中有Shape这个单词,顾名思义,它需要一个形状才能生效
- 2、贝塞尔曲线可以创建基于矢量的路径
- 3、贝塞尔曲线给CAShapeLayer提供路径,CAShapeLayer在提供的路径中进行渲染,路径会闭环,所以路径绘制出了Shape
-
4、用于CAShapeLayer的贝塞尔曲线做为path,其path实一个首尾相接的闭环的曲线,即使该贝塞尔曲线不是一个闭环的曲线
图2.png
如何建立贝塞尔曲线和CAShapeLayer的联系:
- 类:CAShapeLayer
-
属性:path
- 值:可以是贝塞尔曲线对象
UIBezierPath *circle = [UIBezierPath bezierPathWithOvalInRect:CGRectMake(0,0,200,100)];
shape.path = circle.CGPath; -
属性:fillColor 修改贝塞尔曲线的填充颜色
- 值:CGColor对象
-
属性:maskToBounds
- 值:YES 会让超出CAShapeLayer的部分不会显示
一阶贝塞尔曲线
data:image/s3,"s3://crabby-images/4e99a/4e99a894292bf309820dd5e5824a8b1c05fc1094" alt="iOS之UI--CAShapeLayer iOS之UI--CAShapeLayer"
二阶贝塞尔曲线
data:image/s3,"s3://crabby-images/6bbc1/6bbc10c9ffe06408d2be3669650647f784a8694e" alt="iOS之UI--CAShapeLayer iOS之UI--CAShapeLayer"
三阶贝塞尔曲线
data:image/s3,"s3://crabby-images/ac461/ac46188d85b0fd671407085707b55ab6d0047366" alt="iOS之UI--CAShapeLayer iOS之UI--CAShapeLayer"
四阶贝塞尔曲线
data:image/s3,"s3://crabby-images/ee519/ee519489cbc66703178835b8f3db936c1d398fc6" alt="iOS之UI--CAShapeLayer iOS之UI--CAShapeLayer"
五阶贝塞尔曲线
data:image/s3,"s3://crabby-images/f0074/f00740b580fdf015e98b6f750b2f339e779bd506" alt="iOS之UI--CAShapeLayer iOS之UI--CAShapeLayer"
然后是通过代码直接体现贝塞尔曲线和CAShapeLayer之间的关系:
data:image/s3,"s3://crabby-images/0c71c/0c71cdfe67e302f0f416a06f77774c74d8738be9" alt="iOS之UI--CAShapeLayer iOS之UI--CAShapeLayer"
3、strokeStart与strokeEnd动画
- 1、将ShapeLayer的fillColor设置成透明背景
- 2、设置线条的宽度(lineWidth)的值
- 3、设置线条的颜色
4、将strokeStart值设定成0,然后让strokeEnd的值变化触发隐式动画
-
类:CAShapeLayer
-
属性:
- strokeStart
- strokeEnd
- 注意 :strokeEnd的值一定要比strokeStart的大
- 范围 :(0~1)
处理方法:
shapeLayer.strokeStart = valueOne < valueTwo ? valueOne : valueTwo;
shapeLayer.strokeStart = valueOne > valueTwo ? valueOne : valueTwo; -
属性:
- lineWidth 线条的宽度
- strokeColor 线条的颜色
- 值:CGColor
-
data:image/s3,"s3://crabby-images/37be8/37be88f5da67485929017fb5bd6a783d06878392" alt="iOS之UI--CAShapeLayer iOS之UI--CAShapeLayer"
然后为了能实现圆形进度条的效果:
data:image/s3,"s3://crabby-images/2dea1/2dea1b0a323954d41ede3750100c70c6a68aec59" alt="iOS之UI--CAShapeLayer iOS之UI--CAShapeLayer"
效果就是:
data:image/s3,"s3://crabby-images/282f6/282f6c80af556f404f8cf32ce61b1ec6eba236ed" alt="iOS之UI--CAShapeLayer iOS之UI--CAShapeLayer"
将上面的strokeStart也设置,但是注意:strokeStart必须要小于strokeEnd,否则会不画出线的情况。
data:image/s3,"s3://crabby-images/4c98e/4c98e1a7a62d622766b43c443ff127595031c2ec" alt="iOS之UI--CAShapeLayer iOS之UI--CAShapeLayer"
data:image/s3,"s3://crabby-images/caf7c/caf7ce12dc11ceb8e7f7651a09e67590ee02f080" alt="iOS之UI--CAShapeLayer iOS之UI--CAShapeLayer"
4、用CAShapeLayer实现圆形进度条效果,以及更复杂综合起来的动画效果
圆形进度条动画.gif
源码下载地址:CircleProgress 中的 CircleProgress源码
直接更改path的结果,并没有理想中的渐变过程,所以需要使用核心动画:
综合示例源码请看:https://github.com/HeYang123456789/UIView
如果fillColors不设置成 [UIColor clearColor].CGColor就会有这样的效果:
转载请注明原址:http://www.cnblogs.com/goodboy-heyang/p/5185575.html 尊重劳动成果。