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,很少看博客,对你有帮助别忘记点赞收藏。

相关推荐
jinanwuhuaguo13 小时前
OpenClaw执行奇点——因果链折叠与责任悬置的时间哲学(第十九篇)
前端·人工智能·安全·重构·openclaw
为美好的生活献上中指13 小时前
本地虚拟机部署redis集群
前端·redis·ubuntu·bootstrap·html·redis集群
ConardLi13 小时前
开源我的 GPT-Image2 生图 Skill,附大量玩法指南
前端·人工智能·后端
我是Superman丶13 小时前
Antigravity Retry 自动重试脚本
前端·javascript·vue.js
是大强13 小时前
nvm安装node成功npm失败
前端·npm·node.js
scott19851213 小时前
3DGUT与3DGRT
3d
\xin14 小时前
pikachu自编CSRF(GET),CSRF(POST),CSRF(token)
前端·csrf
是大强14 小时前
前端一个项目用node20 一个项目用node14 怎么切换
前端
不老刘14 小时前
Git Cherry-Pick:微前端架构下的“精准医疗”与最佳实践
前端·git
LIO14 小时前
ESLint 极简指南:让代码既规范又一致
前端·eslint