3D 旋转立方体效果(摇塞子)

效果图

.vue

typescript 复制代码
<template>
  <view class="container flex-center">
    <view class="cube">
      <view v-for="(item,index) in 6" :key="index"
            class="cube-item flex-center">
        {{ item }}
      </view>
    </view>
  </view>
</template>

<script setup lang='ts'>

</script>

<style lang='scss' scoped>
.container{
  padding-top: 20vh;
}

@keyframes rotate-cube {
  0%{
    // 1
    transform: rotateX(0deg) rotateY(0deg);
  }

  16.65%{
    // 3
    transform: rotateX(0deg) rotateY(90deg);
  }

  33.3%{
    // 5
    transform: rotateX(90deg) rotateY(0deg);
  }

  49.95%{
    // 6
    transform: rotateX(180deg) rotateY(0deg);
  }

  66.6%{
    // 2
    transform: rotateX(0deg) rotateY(-90deg);
  }

  83.25%{
    // 4
    transform:rotateX(-90deg) rotateY(0deg);
  }

  100%{
    // 1
    transform: rotateX(0deg) rotateY(0deg);
  }
}

.cube{
  --area:400rpx;
  --half:calc(var(--area) / 2);

  width: var(--area);
  height: var(--area);
  font-size: 60rpx;
  transform-origin: var(--half) var(--half) 0;
  transform-style: preserve-3d;
  animation: rotate-cube 7s ease-in-out infinite;
  will-change: transform;

  &-item{
    position: absolute;
    width: var(--area);
    height: var(--area);
    opacity: .8;

    &:nth-child(1){
      background: red;
      transform: rotateY(0deg) translateZ(var(--half));
    }

    &:nth-child(2){
      background: orange;
      transform: rotateY(90deg) translateZ(var(--half));
    }

    &:nth-child(3){
      background: yellow;
      transform: rotateY(-90deg) translateZ(var(--half));
    }

    &:nth-child(4){
      background: green;
      transform: rotateX(90deg) translateZ(var(--half));
    }

    &:nth-child(5){
      background: cyan;
      transform: rotateX(-90deg) translateZ(var(--half));
    }

    &:nth-child(6){
      background: blue;
      transform: rotateY(180deg) translateZ(var(--half)) rotate(180deg);
    }
  }
}
</style>

遇到问题可以看我主页加我Q,很少看博客,对你有帮助别忘记点赞收藏。

相关推荐
kyriewen1 小时前
我手写了一个 EventEmitter,面试官追问了 6 个问题——第 4 个我没答上来
前端·javascript·面试
IT_陈寒1 小时前
Java的Date类又坑了我一次,改用时间戳真香
前端·人工智能·后端
小林攻城狮2 小时前
使用 Transport 节流解决 Vercel AI SDK 流式渲染卡死问题
前端·react.js
前端缘梦2 小时前
告别 TS 运行时类型漏洞!Zod 完整入门实战教程(前端 / 全栈必备)
前端·react.js·全栈
the_answer2 小时前
Webpack vs Vite 深度对比分析
前端·webpack
转转技术团队3 小时前
验证码识别实战:前端不写页面,改训模型了?
前端
MomentYY3 小时前
Temperature:AI 的“脑洞旋钮”
前端·llm·ai编程
远航_3 小时前
OpenSpec 完整详细介绍
前端·后端
召钱熏3 小时前
状态枚举正确≠渲染正确:一个语音按钮的状态机边界修复实录
android·前端
SkyWalking中文站3 小时前
认识 Horizon UI · 1/17:SkyWalking 新一代可观测性控制台
运维·前端·监控