我制作了一个带有立方体的简单动画,它在窗格的边缘移动,并且在每个角落的旋转方式都有麻烦。对于前两个角落它很好并且旋转平稳,但对于其他角落,立方体似乎在它移回位置之前“跳跃”并继续移动。现在我刚刚在我的变换中使用了rotateZ()。
我尝试过像变换起源这样的东西,但我自己找不到解决办法。我不知道还能做什么,因为我不知道原点是否有问题,或者它是否像尺寸问题一样。我还不熟悉动画,所以请原谅任何愚蠢的错误。
请找到下面的代码(目前只有HTML和CSS)。
.perspective {
background: gray;
background-size: 50px 50px;
height: 500px;
left: 50%;
position: absolute;
top: 50%;
width: 500px;
transform: translate(-50%, -50%) rotateX(45deg) rotateZ(45deg);
transform-style: preserve-3d;
-webkit-transform: translate(-50%, -50%) rotateX(45deg) rotateZ(45deg);
-webkit-transform-style: preserve-3d;
backface-visibility: hidden;
}
.cube {
width: 100%;
height: 100%;
position: relative;
transform: scale3d(1.0, 1.0, 1.0) translateZ(25px) translateY(0px) translateX(0px);
transform-origin: 0% 0%;
transform-style: preserve-3d;
animation: test 20s forwards;
}
.cube__face {
position: absolute;
width: 50px;
height: 50px;
background: blue;
}
.cube__face--front {
transform: rotateY( 0deg) translateZ(25px);
background: red;
}
.cube__face--right {
transform: rotateY( 90deg) translateZ(25px);
background: green;
}
.cube__face--back {
transform: rotateY(180deg) translateZ(25px);
background: yellow;
}
.cube__face--left {
transform: rotateY(-90deg) translateZ(25px);
background: pink;
}
.cube__face--top {
transform: rotateX( 90deg) translateZ(25px);
background: purple;
}
.cube__face--bottom {
transform: rotateX(-90deg) translateZ(25px);
background: orange;
}
@keyframes test {
0% {
transform: scale3d(1.0, 1.0, 1.0) translateZ(25px) translateY(0px) translateX(0px);
}
2% {
transform: scale3d(1.0, 1.0, 0.75) translateZ(25px) translateY(0px) translateX(0px);
}
4% {
transform: scale3d(1.0, 1.0, 1.25) translateZ(25px) translateY(75px) translateX(-50px);
}
6% {
transform: scale3d(1.0, 1.0, 1.0) translateZ(25px) translateY(150px) translateX(0px);
}
8% {
transform: scale3d(1.0, 1.0, 0.75) translateZ(25px) translateY(150px) translateX(0px);
}
10% {
transform: scale3d(1.0, 1.0, 1.25) translateZ(25px) translateY(225px) translateX(-50px);
}
12% {
transform: scale3d(1.0, 1.0, 1.0) translateZ(25px) translateY(300px) translateX(0px);
}
14% {
transform: scale3d(1.0, 1.0, 0.75) translateZ(25px) translateY(300px) translateX(0px);
}
16% {
transform: scale3d(1.0, 1.0, 1.25) translateZ(25px) translateY(375px) translateX(-50px);
}
18% {
transform: scale3d(1.0, 1.0, 1.0) translateZ(25px) translateY(450px) translateX(0px);
}
20% {
transform: scale3d(1.0, 1.0, 1.0) translateZ(25px) translateY(450px) translateX(0px);
}
22% {
transform: rotateZ(-90deg) scale3d(1.0, 1.0, 0.75) translateZ(25px) translateX(-500px) translateY(0px);
}
24% {
transform: rotateZ(-90deg) scale3d(1.0, 1.0, 1.25) translateZ(25px) translateX(-450px) translateY(75px);
}
26% {
transform: rotateZ(-90deg) scale3d(1.0, 1.0, 1.0) translateZ(25px) translateX(-500px) translateY(150px);
}
28% {
transform: rotateZ(-90deg) scale3d(1.0, 1.0, 0.75) translateZ(25px) translateX(-500px) translateY(150px);
}
30% {
transform: rotateZ(-90deg) scale3d(1.0, 1.0, 1.25) translateZ(25px) translateX(-450px) translateY(225px);
}
32% {
transform: rotateZ(-90deg) scale3d(1.0, 1.0, 1.0) translateZ(25px) translateX(-500px) translateY(300px);
}
34% {
transform: rotateZ(-90deg) scale3d(1.0, 1.0, 0.75) translateZ(25px) translateX(-500px) translateY(300px);
}
36% {
transform: rotateZ(-90deg) scale3d(1.0, 1.0, 1.25) translateZ(25px) translateX(-450px) translateY(375px);
}
38% {
transform: rotateZ(-90deg) scale3d(1.0, 1.0, 1.0) translateZ(25px) translateX(-500px) translateY(450px);
}
40% {
transform: rotateZ(-90deg) scale3d(1.0, 1.0, 1.0) translateZ(25px) translateX(-500px) translateY(450px);
}
/* X */
42% {
transform: rotateZ(-180deg) scale3d(1.0, 1.0, 0.75) translateZ(25px) translateX(-500px) translateY(-500px);
}
44% {
transform: rotateZ(-180deg) scale3d(1.0, 1.0, 1.25) translateZ(75px) translateX(-500px) translateY(-425px);
}
46% {
transform: rotateZ(-180deg) scale3d(1.0, 1.0, 1.00) translateZ(25px) translateX(-500px) translateY(-350px);
}
48% {
transform: rotateZ(-180deg) scale3d(1.0, 1.0, 0.75) translateZ(25px) translateX(-500px) translateY(-350px);
}
50% {
transform: rotateZ(-180deg) scale3d(1.0, 1.0, 1.25) translateZ(75px) translateX(-500px) translateY(-275px);
}
52% {
transform: rotateZ(-180deg) scale3d(1.0, 1.0, 1.00) translateZ(25px) translateX(-500px) translateY(-200px);
}
54% {
transform: rotateZ(-180deg) scale3d(1.0, 1.0, 0.75) translateZ(25px) translateX(-500px) translateY(-200px);
}
56% {
transform: rotateZ(-180deg) scale3d(1.0, 1.0, 1.25) translateZ(75px) translateX(-500px) translateY(-125px);
}
58% {
transform: rotateZ(-180deg) scale3d(1.0, 1.0, 1.00) translateZ(25px) translateX(-500px) translateY(-50px);
}
60% {
transform: rotateZ(-180deg) scale3d(1.0, 1.0, 1.00) translateZ(25px) translateX(-500px) translateY(-50px);
}
62% {
transform: rotateZ(-270deg) scale3d(1.0, 1.0, 1.00) translateZ(25px) translateY(-500px) translateX(-0px);
}
64% {
transform: rotateZ(-270deg) scale3d(1.0, 1.0, 0.75) translateZ(25px) translateY(-500px) translateX(-0px);
}
66% {
transform: rotateZ(-270deg) scale3d(1.0, 1.0, 1.25) translateZ(75px) translateY(-425px) translateX(-0px);
}
68% {
transform: rotateZ(-270deg) scale3d(1.0, 1.0, 1.00) translateZ(25px) translateY(-350px) translateX(-0px);
}
70% {
transform: rotateZ(-270deg) scale3d(1.0, 1.0, 0.75) translateZ(25px) translateY(-350px) translateX(-0px);
}
72% {
transform: rotateZ(-270deg) scale3d(1.0, 1.0, 1.25) translateZ(75px) translateY(-275px) translateX(-0px);
}
74% {
transform: rotateZ(-270deg) scale3d(1.0, 1.0, 1.00) translateZ(25px) translateY(-200px) translateX(-0px);
}
76% {
transform: rotateZ(-270deg) scale3d(1.0, 1.0, 0.75) translateZ(25px) translateY(-200px) translateX(-0px);
}
78% {
transform: rotateZ(-270deg) scale3d(1.0, 1.0, 1.25) translateZ(75px) translateY(-125px) translateX(-0px);
}
80% {
transform: rotateZ(-270deg) scale3d(1.0, 1.0, 1.00) translateZ(25px) translateY(-50px) translateX(-0px);
}
82% {
transform: rotateZ(-360deg) scale3d(1.0, 1.0, 1.00) translateZ(25px) translateY(0px) translateX(-0px);
}
}
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="utf-8" />
<meta http-equiv="X-UA-Compatible" content="IE=edge">
<title>Cube Test</title>
<meta name="viewport" content="width=device-width, initial-scale=1">
</head>
<body>
<div class="perspective">
<div class="cube">
<div class="cube__face cube__face--front"></div>
<div class="cube__face cube__face--back"></div>
<div class="cube__face cube__face--right"></div>
<div class="cube__face cube__face--left"></div>
<div class="cube__face cube__face--top"></div>
<div class="cube__face cube__face--bottom"></div>
</div>
</div>
</body>
</html>
答案 0 :(得分:1)
我认为转换起源会导致问题,因为您正在尝试同时翻译和旋转。在多维数据集周围添加额外的包装器。然后,将您的翻译应用于外部div,并将您的旋转应用于内部div。
我已经简化了你的例子,但你会得到这个想法:
.perspective {
background: gray;
background-size: 50px 50px;
height: 500px;
left: 50%;
position: absolute;
top: 50%;
width: 500px;
transform: translate(-50%, -50%) rotateX(45deg) rotateZ(45deg);
transform-style: preserve-3d;
backface-visibility: hidden;
}
.wrapper {
width: 50px;
height: 50px;
position: relative;
transform: translate3d(0, 0, 25px);
transform-origin: 0 0 0;
transform-style: preserve-3d;
animation: translation 10s forwards;
}
.cube {
width: 50px;
height: 50px;
position: relative;
transform: rotate3d(0, 0, 0);
transform-origin: 25px 25px 0;
transform-style: preserve-3d;
animation: rotation 10s forwards;
}
.cube__face {
position: absolute;
width: 50px;
height: 50px;
background: blue;
}
.cube__face--front {
transform: rotateY( 0deg) translateZ(25px);
background: red;
}
.cube__face--right {
transform: rotateY( 90deg) translateZ(25px);
background: green;
}
.cube__face--back {
transform: rotateY(180deg) translateZ(25px);
background: yellow;
}
.cube__face--left {
transform: rotateY(-90deg) translateZ(25px);
background: pink;
}
.cube__face--top {
transform: rotateX( 90deg) translateZ(25px);
background: purple;
}
.cube__face--bottom {
transform: rotateX(-90deg) translateZ(25px);
background: orange;
}
@keyframes translation {
0% {
transform: translate3d(0, 0, 25px);
}
25% {
transform: translate3d(0, 450px, 25px);
}
50% {
transform: translate3d(450px, 450px, 25px);
}
75% {
transform: translate3d(450px, 0, 25px);
}
100% {
transform: translate3d(0, 0, 25px);
}
}
@keyframes rotation {
0% {
transform: rotateZ(0);
}
25% {
transform: rotateZ(90deg);
}
50% {
transform: rotateZ(180deg);
}
75% {
transform: rotateZ(270deg);
}
100% {
transform: rotateZ(360deg);
}
}
&#13;
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="utf-8" />
<meta http-equiv="X-UA-Compatible" content="IE=edge">
<title>Cube Test</title>
<meta name="viewport" content="width=device-width, initial-scale=1">
</head>
<body>
<div class="perspective">
<div class="wrapper">
<div class="cube">
<div class="cube__face cube__face--front"></div>
<div class="cube__face cube__face--back"></div>
<div class="cube__face cube__face--right"></div>
<div class="cube__face cube__face--left"></div>
<div class="cube__face cube__face--top"></div>
<div class="cube__face cube__face--bottom"></div>
</div>
</div>
</div>
</body>
</html>
&#13;
答案 1 :(得分:1)
你应该保持立方体运动简单。我已经调整了立方体的两侧,以便它们在没有立方体变换的情况下是alreadyn。
此外,将立方体尺寸设置为看到的立方体尺寸,并将移动中心设置在其中心。
然后一切都变得更容易,如在立方体动画中可以看到的那样
Model
&#13;
.perspective {
background: gray;
background-size: 50px 50px;
height: 400px;
left: 50%;
position: absolute;
top: 50%;
width: 400px;
transform: translate(-50%, -50%) rotateX(45deg) rotateZ(45deg);
transform-style: preserve-3d;
backface-visibility: hidden;
}
.cube {
width: 50px;
height: 50px;
position: relative;
transform-style: preserve-3d;
animation: test 20s linear forwards;
}
.cube__face {
position: absolute;
width: 50px;
height: 50px;
background: blue;
}
.cube__face--front {
transform: rotateY( 0deg) translateZ(50px);
background: red;
}
.cube__face--right {
transform: translateZ(25px) rotateY(90deg) translateZ(25px);
background: green;
}
.cube__face--back {
transform: translateZ(25px) rotateY(180deg) translateZ(25px);
background: yellow;
}
.cube__face--left {
transform: translateZ(25px) rotateY(-90deg) translateZ(25px);
background: pink;
}
.cube__face--top {
transform: translateZ(25px) rotateX( 90deg) translateZ(25px);
background: purple;
}
.cube__face--bottom {
transform: translateZ(25px) rotateX(-90deg) translateZ(25px);
background: orange;
}
@keyframes test {
0% {
transform: translate(0px 0px);
}
20% {
transform: translate(0px, 350px);
}
30% {
transform: translate(0px, 350px) rotateZ(-90deg);
}
45% {
transform: translate(350px, 350px) rotateZ(-90deg);
}
55% {
transform: translate(350px, 350px) rotateZ(-180deg);
}
70% {
transform: translate(350px, 0px) rotateZ(-180deg);
}
80% {
transform: translate(350px, 0px) rotateZ(-270deg);
}
90% {
transform: translate(0px, 0px) rotateZ(-270deg);
}
100% {
transform: translate(0px, 0px) rotateZ(-360deg);
}
}
&#13;