美文网首页iOS开发
动画的微妙之处

动画的微妙之处

作者: 曾宪华 | 来源:发表于2016-04-16 13:22 被阅读163次

本文讲解贝塞尔曲线一部分的使用技巧

nice 标签功能的进化版,先上图,Gif

原文点击这里:http://www.zengxianhua.com/2016/02/16/dong-hua-de-wei-miao-zhi-chu/

XHTagView.gif

概念

贝塞尔曲线(The Bézier Curves),是一种在计算机图形学中相当重要的参数曲线(2D,3D的称为曲面)。

在iOS开发中,我们使用UIBezierPath来绘制贝塞尔曲线的。

UIBezierPath 对象是 CGPathRef 数据类型的封装,如果是基于矢量形状的,都用直线和曲线段去创建,我们使用直线段去创建矩形和多边形,使用曲线段去创建弧(arc),圆或者其他复杂的曲线形状。
每一段都包括一个或者多个点,绘图命令定义如何去诠释这些点。
每一个直线段或者曲线段的结束的地方是下一个的开始的地方。
每一个连接的直线或者曲线段的集合成为SubPath
一个 UIBezierPath 对象定义一个完整的路径包括一个或者多个 SubPaths

创建和使用一个Path对象的过程是分开的。创建 path 是第一步,包含一下步骤:

  • 创建一个 UIBezierPath 对象。
  • 使用方法 moveToPoint: 去设置初始线段的起点。
  • 添加 line 或者 curve 去定义一个或者多个 SubPaths
  • 改变 UIBezierPath 对象跟绘图相关的属性。

我们可以设置 stroked path 的属性 lineWidth 和 lineJoinStyle,也可以设置 filled path 的属性 usesEvenOddFillRule。

当创建 Path,我们应该相对于原点(0,0)管理 Path 上面的点,这样我们在随后就可以很容易的移动 Path 了。为了绘制 Path 对象,我们要用到 stroke 和 fill 方法,这些方法在 Current Graphic Context 下渲染 Path 的 line 和 curve 段。

抽象

有时候在理解动画过程中,我会无从下手,于是乎,我摸索了一个符合自己的方法,就是把动画的步骤分开后进行抽象化。

在这个演示里面我是如何抽象的呢?

分两部分

  • 直线(可以多段)

千万不要着迷,任何简洁的控件你都去绘制,有些可以用图片解决的,尽量用图片来解决。

在你对贝塞尔曲线的概念有一定了解之后,应该能用伪代码进行实现抽象出来的可视化内容了。

move to point
add line 
add line
draw circle
add line
close  

能想象得到是什么吗?从一个点开始,绘制一条直线,再绘制一条直线,然后画一个圆,最后绘制一条直线,闭合路径。

构建

从零碎的伪代码进行完善实现代码,一步一步的构建出动画模型。

UIBezierPath *path = [UIBezierPath new];
[path moveToPoint:CGPointMake(20, 200)];
[path addLineToPoint:CGPointMake(100, 100)];
[path addLineToPoint:CGPointMake(200, 100)];
[path addArcWithCenter:CGPointMake(200 + 5, 100) radius:5 startAngle:M_PI endAngle:(M_PI- 0.1 / 180 * M_PI ) clockwise:YES];
[path addLineToPoint:CGPointMake(100, 100)];
[path closePath];

layer.path = path.CGPath;

封装

对构建好的动画模型进行封装,提供方便的API和样式控制参数。

@class XHBranchLayer;

typedef void(^XHBranchLayerAnimationCompletion)(BOOL finished, XHBranchLayer *branchLayer);

@interface XHBranchLayer : CAShapeLayer

@property (nonatomic, assign) XHBranchLayerDirection direction;

@property (nonatomic, assign) CGPoint startPoint;
@property (nonatomic, assign) CGPoint midPoint;
@property (nonatomic, assign) CGPoint endPoint;

@property (nonatomic, assign) CGFloat radius;
@property (nonatomic, assign) CGFloat toValue;
@property (nonatomic, assign) NSTimeInterval pathDuration;

- (void)animationDelay:(NSTimeInterval)delay
            completion:(XHBranchLayerAnimationCompletion)completion;

@end

组合

通过封装好的动画模型组合成最终动画效果。

6A899D85-0FBE-49CF-8FC0-41B12B3A4BC0.jpg

Demo的源码, -_-吻我

下一期:认真审视自己走过的路

相关文章

  • 动画的微妙之处

    本文讲解贝塞尔曲线一部分的使用技巧 nice 标签功能的进化版,先上图,Gif 原文点击这里:http://www...

  • 写作的微妙之处

    2018年10月,我从零开始写作,刚开始时不懂什么写作技巧,用文字记录自己的当天生活的点滴,是在大脑无意识...

  • 金融世界的微妙之处

    金融市场所有的交易都是认知差的交易,比如在股票市场里,你觉得这支股票已经涨得差不多了,应该没有上涨的空间了,于是你...

  • 婆媳关系中的微妙之处

    2021.3.23亲子关系Day2 学习到:上一讲讲了位置感,婆婆和儿媳都是外人心目中的第一位,潜意识期待婆婆对媳...

  • 改变教育的几个微妙之处(1)

    写在前面 第一,主题由来 结束了中国的传统佳节——春节,迎来了新的一个开学期。很多学校都会利用早于学生报到两三天的...

  • 改变教育的几个微妙之处(2)

    我在3月25日微信公众号发表里谈到改变教育的几个微妙之处(1),具体分享了“知行合一”“公平公正”“以身作则”“倾...

  • 见钱而不收钱微妙之处

    首先要严明的是,这并不是什么贪污受贿的交易,而是存在于现实商业活动的真实场景。 那什么叫见钱而不收钱呢? 线下就是...

  • CH1. UI Design Basics(08)_Animat

    Animation 漂亮微妙的动画遍布iOS UI之内,让App的体验更富魅力和活力。适当的动画可以: 传达状态提...

  • Android动画之属性动画

    属性动画和补间动画的不同之处就是它通过动态改变对象的属性从而达到动画效果,它可以对任何对象做动画,并且动画效果也得...

  • 桥接模式 VS 装饰器模式、状态模式 VS 策略模式的微妙之处

    桥接模式 VS 装饰器模式、状态模式 VS 策略模式的微妙之处 Foundations of Software E...

网友评论

    本文标题:动画的微妙之处

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