Issue
I am attempting to create this beautiful animation using html and css animations keyframes but I am stuck. I have tried changing rotation and transform but i cannot get it to turn out like the image below. You can see from the image below that the boxes fold inwards to hide the text "Hi" and then they unfold outwides which reveals the text again. The box colors is not an issue I'm having a problem with the animation.
Here is what I have done so far.
/* styles.css */
.container {
display: flex;
justify-content: center;
align-items: center;
height: 400px;
}
.group {
display: flex;
flex-direction: column;
justify-content: center;
width: 200px;
margin: 0 15px;
}
.topleft {
width: 100px;
height: 75px;
border-radius: 10px;
margin: 0 auto;
transform-origin: bottom left;
}
.topright {
width: 100px;
height: 75px;
border-radius: 10px;
margin: 0 auto;
transform-origin: bottom left;
}
.bottomleft {
width: 100px;
height: 75px;
border-radius: 10px;
margin: 0 auto;
transform-origin: bottom right;
}
.bottomright {
width: 100px;
height: 75px;
border-radius: 10px;
margin: 0 auto;
transform-origin: bottom left;
}
.topleft {
background-color: steelblue;
animation: rotateTopLeft 2s linear infinite;
}
.topright {
background-color: steelblue;
animation: rotateTopRight 2s linear infinite;
}
.bottomleft {
background-color: steelblue;
animation: rotateTopLeft 2s linear infinite;
}
.bottomright {
background-color: steelblue;
animation: rotateTopRight 2s linear infinite;
}
@keyframes rotateTopLeft {
0% {
transform: rotate(0deg);
}
100% {
transform: rotate(-90deg);
}
}
@keyframes rotateTopRight {
0% {
transform: rotate(0deg);
}
100% {
transform: rotate(-90deg);
}
}
@keyframes rotateBottomLeft {
0% {
transform: rotate(0deg);
}
100% {
transform: rotate(90deg);
}
}
@keyframes rotateBottomRight {
0% {
transform: rotate(0deg);
}
100% {
transform: rotate(-90deg);
}
}
.bottomleft {
background-color: yellow;
}
.topright {
background-color: rosybrown;
}
.topright {
background-color: diegray;
}
.space {
width: 100px;
height: 75px;
display: flex;
justify-content: center;
align-items: center;
font-size: 24px;
}
<div class="container">
<div class="group left">
<div class="box topleft steelblue"></div>
<div class="box bottomleft yellow"></div>
</div>
<div class="space">Hi</div>
<div class="group right">
<div class="box topright diegray"></div>
<div class="box bottomright rosybrown"></div>
</div>
</div>
Solution
Here is my idea. Hover to see the animation:
.box {
width: 200px;
aspect-ratio:1;
display: grid;
place-content: center;
margin: auto;
font-size: 40px;
position: relative;
}
.box:before,
.box:after,
.box span:before,
.box span:after {
content:"";
position: absolute;
width: 50%;
height: 50%;
transition: 1s;
}
.box:before {
inset: 0 auto auto 0;
transform-origin: 0 0;
background: pink;
rotate: var(--r,0deg);
}
.box:after {
inset: 0 0 auto auto;
transform-origin: 100% 0;
background: lightblue;
rotate: calc(-1*var(--r,0deg));
}
.box span:before {
inset: auto auto 0 0;
transform-origin: 0 100%;
background: red;
rotate: calc(-1*var(--r,0deg));
}
.box span:after {
inset: auto 0 0 auto;
transform-origin: 100% 100%;
background: blue;
rotate: var(--r,0deg);
}
.box:hover {
--r: 90deg;
}
<div class="box">
hi
<span></span>
</div>
Answered By - Temani Afif
0 comments:
Post a Comment
Note: Only a member of this blog may post a comment.