我是靠谱客的博主 忐忑芒果,这篇文章主要介绍一文讲解css3实现椭圆轨迹旋转(总结),现在分享给大家,希望可以做个参考。

css3实现椭圆轨迹旋转

最近需要实现如下效果

145.gif

最开始用css3D旋转写,只能实现如下效果

GI444F.gif

没办法把所有的圆转向正面,不知道是我的操作不对,还是3d旋转无法实现,有知道的大佬还请赐教啊

没法用3d实现只能转向2d了,只要实现按椭圆旋转就ok了

1、X轴Y轴在一个矩形内移动

路径为斜线

复制代码
1
2
3
4
5
6
7
8
9
10
11
12
13
.ball { animation: animX 2s linear infinite alternate, animY 2s linear infinite alternate } @keyframes animX{ 0% {left: 0px;} 100% {left: 500px;} } @keyframes animY{ 0% {top: 0px;} 100% {top: 300px;} }
登录后复制

475.gif

2、设置动画延迟

设置Y轴动画延迟为动画时长的一半(延迟设为负数动画开始不会有延迟空白,感兴趣的同学可以试试正数延迟),可以看到运动轨迹变成菱形了,有点感觉了

复制代码
1
2
3
4
5
.ball { animation: animX 2s linear 0s infinite alternate, animY 2s linear -1s infinite alternate }
登录后复制

78.gif

3、设置三次贝塞尔曲线

复制代码
1
2
3
4
5
.ball { animation: animX 2s cubic-bezier(0.36, 0, 0.64, 1) -1s infinite alternate, animY 2s cubic-bezier(0.36, 0, 0.64, 1) 0s infinite alternate }
登录后复制


kjj.gif

4、缩小放大

为了看起来有立体感添加scale属性,scale动画应该是X轴和Y轴的时间总和

复制代码
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
.ball1 { animation: animX 2s cubic-bezier(0.36, 0, 0.64, 1) -1s infinite alternate, animY 2s cubic-bezier(0.36, 0, 0.64, 1) 0s infinite alternate, scale 4s cubic-bezier(0.36, 0, 0.64, 1) 0s infinite alternate; } @keyframes scale { 0% { transform: scale(0.7) } 50% { transform: scale(1) } 100% { transform: scale(0.7) } }
登录后复制

fergr.gif

大功告成!

推荐学习:CSS3视频教程

以上就是一文讲解css3实现椭圆轨迹旋转(总结)的详细内容,更多请关注靠谱客其它相关文章!

最后

以上就是忐忑芒果最近收集整理的关于一文讲解css3实现椭圆轨迹旋转(总结)的全部内容,更多相关一文讲解css3实现椭圆轨迹旋转(总结)内容请搜索靠谱客的其他文章。

本图文内容来源于网友提供,作为学习参考使用,或来自网络收集整理,版权属于原作者所有。
点赞(126)

评论列表共有 0 条评论

立即
投稿
返回
顶部