时间:2021-05-20
前言:最近公司项目有个需求,需要实现让一个view沿着椭圆轨迹做动画,效果实现后,就自己封装做了一个小demo,使用更方便。先看效果:
椭圆.gif
效果图中的白色椭圆轨迹线其实是用贝塞尔曲线画出来的,为了清晰的看出来运动的轨迹。其实项目中是不显示轨迹线的,也就是小球是悬空运动的。若不需要删除掉即可。
实现步骤:
1.首先设定关键帧动画CAKeyframeAnimation的一些属性,比如运动时间和重复次数和calculationMode模式,我们选择kCAAnimationPaced 使得动画均匀进行。
CAKeyframeAnimation *pathAnimation = [CAKeyframeAnimation animationWithKeyPath:@"position"]; pathAnimation.calculationMode = kCAAnimationPaced; pathAnimation.fillMode = kCAFillModeForwards; pathAnimation.removedOnCompletion = NO; pathAnimation.duration = 5.0; pathAnimation.repeatCount = 2;2.设定好关键帧动画的path,即一个椭圆形的路径。需要使用CGPathAddArc,CGPathAddArc经常用于画正圆,比如下面就是一个正圆,各个参数的意义:
//160,200为圆心,100为半径 (startAngle,endAngle)为起始角度和结束角度,1为顺时针,0 为逆时针
CGPathAddArc(curvedPath, NULL, 160,200, 100, startAngle, endAngle, 0);
需要注意的是由于iOS中的坐标体系是和Quartz坐标体系中Y轴相反的,所以iOS UIView在做Quartz绘图时,Y轴已经做了Scale为-1的转换,因此造成CGPathAddArc函数最后一个是否是顺时针的参数结果正好是相反的,也就是说如果设置最后的参数为YES,根据参数定义应该是顺时针的,但实际绘图结果会是逆时针的!
我们需要画的是椭圆啊,别急,接下来稍作更改即可。正圆第二个参数默认为NULL,我们要改成椭圆,
//短半轴和长半轴的比例 float radiuscale = 0.5; //椭圆顶点的坐标值 CGFloat origin_x = self.frame.size.width/2; CGFloat origin_y = self.frame.size.height/2; //长半轴的长 CGFloat radiusX = 100; CGMutablePathRef curvedPath = CGPathCreateMutable(); CGAffineTransform t2 = CGAffineTransformConcat(CGAffineTransformConcat( CGAffineTransformMakeTranslation(-origin_x, -origin_y), CGAffineTransformMakeScale(1, radiuscale)), CGAffineTransformMakeTranslation(origin_x, origin_y)); CGPathAddArc(curvedPath, &t2, origin_x, origin_y, radiusX,startAngle,endAngle, 1); pathAnimation.path = curvedPath; CGPathRelease(curvedPath);好了,至此,动画的轨迹和属性都写好了。添加到view上就ok了。
3.贝塞尔画椭圆
如果是整个椭圆的话,只需要设定好理想中的椭圆的外切圆即可。
//整个椭圆 CGContextRef context = UIGraphicsGetCurrentContext(); CGContextSaveGState(context); UIBezierPath *arc = [UIBezierPath bezierPathWithOvalInRect:CGRectMake(origin_x-100, origin_y-50, 200, 100)]; [[UIColor whiteColor] setStroke]; [arc stroke]; CGContextRestoreGState(context);总结: 希望本文能对你有帮助。如果你有更好的想法,欢迎和我交流!
demo地址:https://github.com/xiaochenyi/CircleAnimateDemo
文/秋雨W(简书作者)
原文链接:http:///p/d8cc02e7efa7
著作权归作者所有,转载请联系作者获得授权,并标注“简书作者”。
声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
我们知道,在平面内到两个定点的距离之和等于定长的点的轨迹是椭圆,这是椭圆的定义,如何制作椭圆定义演示动画呢,如下图。今天小编手把手教你制作这个课件。软件名称:n
ae做的轨迹动画,想要修改运动轨迹时,该怎么修改呢?下面我们就来看看详细的教程。软件名称:AdobeAfterEffectsCC2017V14.2.1中文版64
椭圆机开机的方法: 一般是踩上去发动了就可以启动了。 椭圆机区别于其他有氧健身器材,腿部运动轨迹也是椭圆的,运动时感觉是在走路或者跑步,减少对膝盖的损伤,深
最终效果如下:动画分成两步制定运行轨迹创建DOM并按照轨迹动画制定运行轨迹我们先要画一条底部的淡蓝色半透明路劲做为能量流动的管道这里用SVG的path去做(其实
本文实例讲述了jsdiv拖动动画运行轨迹效果。分享给大家供大家参考。具体如下:这是一款基于js实现的div拖动动画运行轨迹效果源码,是一款原生jsdiv拖动效果