Popmotion: эффект отказов
Как видно ниже, я попытался создать эффект отскока в конце другой анимации в Popmotion.
Я не был уверен, как это сделать, поэтому я попытался изменить скорость, как только она достигнет определенного порога.
Результаты являются спорадическими и не всегда работают.
Любые идеи о том, как лучше всего создать эффект отказов с Popmotion?
Пояснение 1
Мяч отскакивает большую часть времени, но как долго он отскакивает, сильно варьируется. Иногда это резко останавливается после одного удара. Я не уверен, почему это так, потому что я не до конца понимаю, как на самом деле работает решение. Почему это замедляется, если мы просто изменяем скорость. Глядя на код, я думаю, что шар будет колебаться бесконечно, но это не так.
Пояснение 2
В Firefox 65.0.1
анимация кажется последовательной. В Chrome 72.x
действует нерационально. Т.е. длина анимации и отскока меняется каждый раз.
const {
tween,
styler,
value,
easing,
physics,
transform
} = popmotion;
const {
clamp,
pipe,
conditional
} = transform;
const ball = document.querySelector('#ball');
const ballStyler = styler(ball);
const ballY = value(0, ballStyler.set('y'));
const BOTTOM = 50;
const pipedPhysics = physics({
acceleration: 2000,
// friction: 0.5,
// restSpeed: 0,
// springStrength: 300,
// to: 50
}).pipe(clamp(0, BOTTOM));
const anim = pipedPhysics.start(ballY);
ballY.subscribe(v => {
if (v >= BOTTOM) {
anim.setVelocity(-ballY.getVelocity());
};
// console.log('v, vel: ', v, ballY.getVelocity());
});
#ball {
background: #ff2420;
border-radius: 50%;
position: absolute;
left: 50%;
width: 50px;
height: 50px;
margin: 0px;
transform-origin: 50%;
}
<script src="https://unpkg.com/popmotion/dist/popmotion.global.min.js"></script>
<div id="ball"></div>