CSS ์ ๋๋ฉ์ด์ : ๋ง์ฐ์ค๋ฅผ ๋ฐ๋ผ๊ฐ๋ ๋์
์ค๋์ ๋ง์ฐ์ค๋ฅผ ๋ฐ๋ผ ๋์์ด ๋น๊ธ๋น๊ธ ๋์๊ฐ๋ ์ ๋๋ฉ์ด์ ์ ๋ง๋ค์ด ๋ณด๋๋ก ํ๊ฒ ์ต๋๋ค. ์์ ํด๋ณผ ์ ๋๋ฉ์ด์ ์ ๋ค์๊ณผ ๊ฐ์ต๋๋ค.
1. HTML ์์ค
<div class="wrapper">
<div class="card">
<div class="me">
<div class="eye"></div>
</div>
<div class="text">EYE</div>
</div>
</div>
wrapper ์์ card, card ์์ me์ text, me ์์ eye ํด๋์ค๋ฅผ ๊ฐ์ง div ๋ฐ์ค๋ฅผ ๋ง๋ค์ด ์ค๋๋ค. text๋ ์์ ๋กญ๊ฒ ์์ฑํฉ๋๋ค.
2. CSS ์์ค
* {
margin: 0;
padding: 0;
box-sizing: border-box;
}
html, body {
height: 100%;
overflow: hidden;
}
.wrapper {
position: absolute;
left: 50%;
top: 50%;
width: 369px;
height: 547px;
transform-style: preserve-3d;
transform: translate(-50%, -50%);
}
.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(https://slack-imgs.com/?c=1&o1=ro&url=http%3A%2F%2Fwww.supah.it%2Fdribbble%2F006%2Fprofile.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(0.55);
border: 3px solid #fff;
text-align: center;
font-size: 35px;
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: 'moving';
width: 100%;
position: absolute;
bottom: 22px;
left: 0;
z-index: 1;
line-height: 1;
font-size: 24px;
text-align: center;
text-transform: uppercase;
letter-spacing: 29px;
text-indent: 20px;
}
์ด๋ฏธ์ง์ ํ๋ ์์ ๋ง๋ค๊ณ , ๊ฐ๊ฐ์ ์ด๋ฏธ์ง ์์น๋ฅผ ์กฐ์ ํด ์ค๋๋ค.
3. JAVASCRIPT ์์ค
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();
keydown ์ด๋ฒคํธ๋ ๋ฐฉํฅํค๋ฅผ ๋๋ ์ ๋ ๋์์ด ํด๋น ๋ฐฉํฅ์ ๋ฐ๋ผ๋ณด๋๋ก ์์ ํด ์ฃผ์์ต๋๋ค.
์์ HTML, CSS, JAVASCRIPT ์์ค๋ฅผ ํฉ์น๋ฉด ์ ๋๋ฉ์ด์ ์ด ์์ฑ๋ฉ๋๋ค. ์์งํ ์ง๊ทธ๋ฝ๋ค์...
'CSS' ์นดํ ๊ณ ๋ฆฌ์ ๋ค๋ฅธ ๊ธ
CSS ์ ๋๋ฉ์ด์ ๋ง๋ค๊ธฐ : ๋ก๋ฉ ์ ๋๋ฉ์ด์ (6) | 2022.09.24 |
---|---|
CSS ์ ๋๋ฉ์ด์ ๋ง๋ค๊ธฐ : 3D ๋ฐ์ค ์ ๋๋ฉ์ด์ (9) | 2022.09.22 |
CSS ์ ๋๋ฉ์ด์ ๋ง๋ค๊ธฐ : ํตํต ํ๋ ๊ธ์ (1) | 2022.09.22 |
CSS ์ ๋๋ฉ์ด์ ๋ง๋ค๊ธฐ : ์นด๋ ๋ค์ง๊ธฐ (9) | 2022.09.20 |
CSS ์ ๋๋ฉ์ด์ ๋ง๋ค๊ธฐ : ์ผ๋ ์ด๋ ์ ๋๋ฉ์ด์ (8) | 2022.09.19 |
๋๊ธ