css3实现椭圆轨迹运动

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

做斜线运动
此处left top 为矩形右下角的值
在这里插入图片描述

.ball {
    position: absolute;
    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;}
}
2、设置动画延时

设置Y轴延时为动画时长的一半, 运动轨迹变成菱形
在这里插入图片描述

.ball {
     animation: 
       animX 2s linear 0s infinite alternate,
       animY 2s linear -1s infinite alternate
 }
3、设置三次贝塞尔曲线
.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
 }

在这里插入图片描述

4、缩小放大

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

.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)
   }
 }

在这里插入图片描述
本来是想记录自己做的图形 可是发现自己的没有gif图 无奈就全部参考过来了 就当是自己又学习一遍了吧

参考
https://segmentfault.com/a/1190000016822437?utm_source=tag-newest

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值