Я попытался создать этот эффект с помощью переходов. Это должно выглядеть так, будто вы открываете коробку.
Есть 2 проблемы:
- Порядок, в котором окно закрывается, совпадает с порядком, в котором он открывается. Стоит ли закрывать коробку в обратном порядке ее открытия, чтобы окно возвращалось в том же состоянии, когда оно было закрыто?
- Концы зеленых и желтых лоскутов скрыты во время перехода из-за красных и синих лоскутов, поэтому он не выглядит 3D. Есть ли способ показать все закрылки в 3D-режиме?
Я бы предпочел, чтобы решение было в чистом CSS, без JavaScript.
#box {
position: relative;
top: 170px;
left: 170px;
width: 300px;
height: 300px;
border: 1px solid black;
perspective: 800px;
}
#flap1, #flap2, #flap3, #flap4 {
position: absolute;
}
#flap1 {
background-color: red;
width: 150px;
height: 300px;
z-index: 1;
transform-origin: 0 0;
transition: transform 1s;
}
#flap2 {
left: 150px;
background-color: blue;
width: 150px;
height: 300px;
z-index: 1;
transform-origin: 100% 0;
transition: transform 1s ease 0.3s;
}
#flap3 {
background-color: green;
width: 300px;
height: 150px;
transform-origin: 0 0;
transition: transform 1s ease 0.6s;
}
#flap4 {
background-color: yellow;
top: 150px;
width: 300px;
height: 150px;
transform-origin: 0 100%;
transition: transform 1s ease 0.9s;
}
#box:hover #flap1{
transform: rotateY(-170deg);
}
#box:hover #flap2{
transform: rotateY(170deg);
}
#box:hover #flap3{
transform: rotateX(170deg);
}
#box:hover #flap4{
transform: rotateX(-170deg);
}
<html>
<head>
<link rel="stylesheet" href="style.css">
</head>
<body>
<div id="box">
<div id="flap1"></div>
<div id="flap2"></div>
<div id="flap3"></div>
<div id="flap4"></div>
</div>
</body>
</html>