CSS动画倍速播放

背景

要测试大转盘动画在不同转速下的效果。

通过动画持续时间影响倍速

完成一次动画的持续时间越短,动画越快。因此将初始动画持续时间除以倍速即可。

示例CSS代码:

css 复制代码
.App {
  font-family: sans-serif;
  text-align: center;
}

.turntable-container {
  display: flex;
  justify-content: center;
  align-items: center;
  height: 100vh;
  background-color: #f0f0f0;
}

.turntable {
  width: 300px;
  height: 300px;
  border-radius: 50%;
  position: relative;
  overflow: hidden;
  animation: rotate calc(2s / var(--animation-speed)) linear infinite; /* 初始2秒一圈 */

  border: 10px solid #f8d38d;
  /* 使用圆锥渐变:每 45度 切换一个颜色,实现 8等分 */
  background: conic-gradient(
    #ff6b6b 0deg 45deg,
    #4ecdc4 45deg 90deg,
    #ff6b6b 90deg 135deg,
    #4ecdc4 135deg 180deg,
    #ff6b6b 180deg 225deg,
    #4ecdc4 225deg 270deg,
    #ff6b6b 270deg 315deg,
    #4ecdc4 315deg 360deg
  );
  box-shadow: 0 0 20px rgba(0, 0, 0, 0.2);
}

@keyframes rotate {
  from {
    transform: rotate(0deg);
  }
  to {
    transform: rotate(360deg);
  }
}

示例js代码:

javascript 复制代码
import { useEffect, useState } from "react";
import "./styles.css";

export default function App() {
  const [animationSpeed, setAnimationSpeed] = useState(1);

  useEffect(() => {
    // 开启2倍速播放
    setAnimationSpeed(2);
  }, []);

  return (
    <div className="App">
      <div class="turntable-container">
        <div
          class="turntable"
          style={{ "--animation-speed": animationSpeed }}
        ></div>
      </div>
    </div>
  );
}

效果演示

正常倍速:

正常倍速大转盘

2倍速:

2倍速播放大转盘

小结

综上,我们使用CSS圆锥渐变实现了一个简易大转盘,并使其按照2秒1圈的速度匀速转动。js中维护了animationSpeed状态代表倍速,初始值为1。通过将其设置为2实现2倍速播放。实战中,我们需要对希望支持倍速播放的动画的每一部分的动画持续时间都做CSS变量的插值,防止出现时间轴错乱的情况。

相关推荐
果然_5 小时前
为什么你的 PR 总是多出一堆奇怪的 commit?90% 的人都踩过这个 Git 坑
前端·git
xpyjs5 小时前
零依赖、链式调用、可变对象:重新设计 JavaScript 颜色处理体验
前端
WayneYang5 小时前
Node.js 全栈知识点详细整理(含代码示例 + 前端结合实战)
前端·node.js
土拨鼠爱coding5 小时前
Chrome插件 - DIY Theme
前端·chrome
小赵同学WoW5 小时前
CSS作用域穿透选择器
前端·css
GreenTea5 小时前
Deep Dive into Claude Code:源码泄漏引发的AI Agent架构全解析
前端·人工智能·后端
RePeaT5 小时前
【Next.js】基础知识速查
前端·react.js·next.js
yyuuuzz5 小时前
独立站搭建:从入门到避坑实战
前端·git·github
OpenTiny社区6 小时前
WebSkill —— 运行在浏览器的 Agent 技能
前端·开源·ai编程
Amos_Web6 小时前
Solana 智能合约编译问题排查与修复总结
前端·rust·区块链