728x90
공이 돌아가는 애니메이션을 구현해보자~!
이번에는 눈알이 마우스를 따라 돌아가는 효과를 한번 구현해볼게요!!
HTML 코드
html 코드는 별로 작성할게 없습니다
하단과 같이 작성 후 원하는 글자를 .text 클래스에 작성해 커스텀 하면 되더라구요!
<div class="wrapper">
<div class="card">
<div class="me">
<div class="eye"></div>
</div>
<div class="text">ABCDE</div>
</div>
</div>
CSS 코드
기본 적으로 모든 요소가 가운데에 정렬되고 살을 붙여주기 위해 하단과 같이 css 코드를 작성합니다.
*{
margin: 0;
padding: 0;
box-sizing: border-box;
}
html, body{
height: 100%;
overflow: hidden;
}
.wrapper{
position: absolute;
left: 50%;
top: 50%;
transform: translate(-50%, -50%);
width: 369px;
height: 547px;
transform-style: preserve-3d;
perspective: 600px;
}
.me{
position: absolute;
width: 369px;
height: 547px;
transform: translateZ(80px) scale(0.8);
}
.me::before,
.me::after{
position: absolute;
content: '';
width: 100%;
height: 100%;
top: 0;
left: 0;
border-radius: 10px;
background: url(http://www.supah.it/dribbble/006/profile.png) no-repeat 0 0;
}
.me::after {
height: 30px;
top: auto;
bottom: -15px;
filter: blur(15px);
background-size: 100% 30px;
border-radius: 100px;
}
.eye, .eye::before{
width: 70px;
height: 70px;
position: absolute;
top: 175px;
left: 119px;
z-index: -1;
background: url(http://www.supah.it/dribbble/006/eye.png)
}
.eye::before{
content: '';
top: -3px;
left: 99px;
}
.text{
position; absolute;
left: 0;
top: 0;
z-index: 2;
width: 390px;
height: 595px;
transform: translatez(150px) translatex(-11px) translatey(-26px) scale(.55);
border: 3px solid #fff;
text-align: center;
line-height: 1000px;
color: #fff;
opacity: 0.3;
border-radius: 15px;
background: linear-gradient(135deg, #fff 0%, rgba(255,255,255,0.36) 39%, rgba(255,255,255,0) 51%, #000 100%)
}
.text::after {
content: 'eye moving';
width: 100%;
position: absolute;
bottom: 22px;
left: 0;
z-index: 1;
line-height: 1;
font-size: 18px;
text-align: center;
text-transform: uppercase;
letter-spacing: 20px;
text-indent: 20px;
}
JS 코드
1. wrap이라는 변수에 .wrapper 클래스를 담아 가운데에 고정시켜준뒤
2. 브라우저의 중심을 기준으로 마우스가 위치한 좌표의 값을 구한 뒤
3. 각각 wrap(.wrapper) 와 eye(.eye) 변수에 translate를 통해
4. 이를 통해 마우스를 따라 눈이 움직이고 카드가 같이 움직이는 듯한 효과를 줍니다!
const wrap = document.querySelector('.wrapper');
const eye = document.querySelector('.eye');
const speed = 1;
let x = 0;
let y = 0;
let followX = 0;
let followY = 0;
function animate() {
x += (followX - x) * speed;
y += (followY - y) * speed;
eye.style.transform = `translate(${-x}px, ${-y}px)`;
wrap.style.transform = `translate(-50%,-50%) perspective(600px) rotateX(${-y}deg) rotateY(${-x}deg)`;
requestAnimationFrame(animate);
}
window.addEventListener('mousemove', (e) => {
let mouseX = Math.max(-100, Math.min(100,window.innerWidth / 2 - e.clientX));
let mouseY = Math.max(-100, Math.min(100,window.innerHeight / 2 - e.clientY));
followX = (12 * mouseX) / 100;
followY = (10 * mouseY) / 100;
});
window.addEventListener('keydown', (e)=>{
switch(e.keyCode) {
case 37:
followX = 12;
break;
case 38:
followY = 10;
break;
case 39:
followX = -12;
break;
case 40:
followY = -10;
break;
default:
break;
}
});
animate()
왼성!
완성하고 나니까 많이 기괴하네요 ㅋㅋㅋㅋㅋㅋㅋ
728x90
반응형
'CSS 애니메이션' 카테고리의 다른 글
CSS를 통해 로딩화면 만들어보기 : 가운데를 중심으로 돌아가는 원들 (6) | 2022.09.25 |
---|---|
점점 Long 해졌다가 Short 해지는 박스 애니메이션 만들기 (11) | 2022.09.22 |
CSS로 3D hover 효과를 구현해보자! (5) | 2022.09.20 |
원이 펄럭이는 애니메이션 만들어보기! (3) | 2022.09.19 |
무한으로 뛰어오르는 공 만들어 보자! (7) | 2022.09.02 |
댓글