gpt4 book ai didi

css - 在固定路径上加速动画

转载 作者:太空宇宙 更新时间:2023-11-04 10:30:16 25 4
gpt4 key购买 nike

我有以下代码使球沿着正弦波的路径动画:

.ball {
animation: animX 5s infinite linear;
}

.ball::after {
position: absolute;
top: 100px;
animation: animY 5s infinite;
background-color: green;
width: 20px;
height: 20px;
border-radius: 50%;
content:'';
display: block;
}

@keyframes animX {
0% {
transform: translateX(0px);
}
25% {
transform: translateX(125px);
}
75% {
transform: translateX(375px);
}
100% {
transform: translateX(500px);
}
}

@keyframes animY {
0% {
transform: translateY(0px);
animation-timing-function: ease-out;
}
25% {
transform: translateY(-50px);
animation-timing-function: ease-in-out;
}
75% {
transform: translateY(50px);
animation-timing-function: ease-in-out;
}
100% {
transform: translateY(0px);
animation-timing-function: ease-in;
}
}
<div class="ball"/>

我正在尝试在此动画中添加另外两件事,它们仅适用于动画的最后 25%:

  1. 圆应该加速到起始速度的两倍,沿着同一条路。
  2. 圆应该缩小到原来大小的 30%

对于 1. 我已经尝试更改动画最后阶段的 animation-timing-function,但它似乎扭曲了圆的路径,这是我不想要的。对于 2。我尝试将 scale(0.3) 添加到 transform 规则中,但这似乎也弄乱了球的路径。我需要做一些技巧来使这些事情独立于路径发生吗?

最佳答案

第一个

/* Styles go here */

.ball {
animation: animX 5s infinite linear;
}

.ball::after {
position: absolute;
top: 100px;
animation: animY 5s infinite;
background-color: green;
width: 20px;
height: 20px;
border-radius: 50%;
content:'';
display: block;
}

@keyframes animX {
0% {
transform: translateX(0px);
}
25% {
transform: translateX(125px);
}
75% {
transform: translateX(375px);
}
80% {
transform: translateX(400px);
}
85% {
transform: translateX(405px);
}
90% {
transform: translateX(425px);
}
95% {
transform: translateX(555px);
}
100% {
transform: translateX(600px);
}
}

@keyframes animY {
0% {
transform: translateY(0px);
animation-timing-function: ease-out;
}
25% {
transform: translateY(-50px);
animation-timing-function: ease-in-out;
}
75% {
transform: translateY(50px);
animation-timing-function: ease-in-out;
}
100% {
transform: translateY(0px);
transform:scale(0.3);
animation-timing-function: cubic-bezier(.92,.02,.74,1.03);
}
}
<!DOCTYPE html>
<html>
<body>
<div class="ball"/>
</body>
</html>

添加变换:scale(0.3);

100% {
transform: translateY(0px);
transform:scale(0.3);
animation-timing-function: ease-in;
}

关于第二个,我认为你需要玩一下 cubic-bezier 计时功能 http://cubic-bezier.com/

关于css - 在固定路径上加速动画,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/36532928/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com