How to use CSS animations to create a cube's opening like in the picture?

后端 未结 1 1895
难免孤独
难免孤独 2021-01-18 23:58

In my project, when the homepage is opened, it should run a CSS animation so that the cube\'s faces open. After the animation is complete the faces should be like in the pic

相关标签:
1条回答
  • 2021-01-19 00:28

    Judging by the description, snippet and the picture provided in question it seems like you are trying to create a flat cube opening animation where each face of the cube opens one by one and ends up with the appearance as shown in the first sample within the picture.

    It might be possible to achieve that effect by enhancing your current code but I found it a bit confusing and so went with my own version of a flat-cube.

    Explanation:

    • First create a cube with six faces (one div element for each face). I've made the front face as a child element of the left face element because the front face should eventually get opened on the left hand side of the left face.
    • Each face is a 50 x 50px square whose transform and transform-origin properties are set in such a way that it creates a cube.
    • Opening animation is then attached to each of the faces and a delay is added depending on when each face should get opened. In the demo, the right face gets opened first and so it has no delay, the bottom face is opened second and so it has a delay of 1s (equal to the animation time of right face), the top face is opened third and so has a delay of 2s (equal to combined animation time of the previous two faces) and so on.
    • The back face doesn't have any animation attached because it doesn't need to open at all ;)

    .cube {
      position: relative;
      margin: 100px;
      transform-style: preserve-3d;
    }
    .cube div {
      position: absolute;
      height: 50px;
      width: 50px;
      transform-style: preserve-3d;
    }
    .back {
      background: rebeccapurple;
    }
    .right {
      background: tomato;
      transform: rotateY(90deg);
      transform-origin: right;
      animation: open-y 1s ease-in-out forwards;
    }
    .bottom {
      background: crimson;
      transform: rotateX(270deg);
      transform-origin: bottom;
      animation: open-x 1s 1s ease-in-out forwards;
    }
    .top {
      background: indianred;
      transform: rotateX(90deg);
      transform-origin: top;
      animation: open-x 1s 2s ease-in-out forwards;
    }
    .left {
      background: yellowgreen;
      transform: rotateY(270deg);
      transform-origin: left;
      animation: open-y 1s 3s ease-in-out forwards;
    }
    .front {
      background: chocolate;
      transform: rotateY(270deg);
      transform-origin: right;
      animation: open-y 1s 3s ease-in-out forwards;
    }
    @keyframes open-y {
      to {
        transform: rotateY(180deg);
      }
    }
    @keyframes open-x {
      to {
        transform: rotateX(180deg);
      }
    }
    <div class="cube">
      <div class="back"></div>
      <div class="right"></div>
      <div class="bottom"></div>
      <div class="top"></div>
      <div class="left">
        <div class="front"></div>
      </div>
    </div>

    Note: It is very much possible to achieve a similar effect in other ways also and in addition make them look a lot more realistic but that would most likely involve a good amount of translate transforms, extra keyframe settings for the animations etc - in short, a lot more complex code.

    0 讨论(0)
提交回复
热议问题