[Toy Project] 웹페이지에서 랜덤한 픽셀 떨어뜨리기 애니메이션 구현하기 [CSS 애니메이션과 JavaScript 활용]

2024. 8. 5. 14:50·◈ Yermi Project/Toy Project💎
728x90
반응형

- 웹페이지에서 랜덤한 픽셀 떨어뜨리기 애니메이션 구현하기

웹페이지에서 픽셀들이 화면 상단에서 하단으로 랜덤하게 떨어지는 간단한 애니메이션을 구현해보려 한다.
HTML, CSS, JavaScript를 사용하여 간단하게 만들어 볼 것이다.

쏟아져라, 픽셀들이여☃️


- falling-pixels.html

  • HTML 파일에서는 기본적인 구조와 컨테이너 요소(pixel-container)를 정의한다.
  • pixel-container는 픽셀들이 떨어질 영역을 지정한다.
<!DOCTYPE html>
<html lang="ko">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Pixel Falling Animation</title>
    <link rel="stylesheet" href="/falling-pixels/falling-pixels.css">
</head>
<body>
    <div id="pixel-container"></div>
    <script src="/falling-pixels/falling-pixels.js"></script>
</body>
</html>

-falling-pixels.css

  • pixel-container와 pixel 클래스에 대한 스타일을 지정한다.
  • 픽셀의 크기, 초기 위치, 애니메이션 키프레임(@keyframes fall)을 설정하여 픽셀들이 떨어지는 동작을 구현한다.
body {
    margin: 0;
    padding: 0;
    overflow: hidden;
    background-color: #000;
}

#pixel-container {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    pointer-events: none;
}

.pixel {
    position: absolute;
    width: 5px;
    height: 5px;
    background-color: #fff;
    animation: fall 5s linear infinite;
}

@keyframes fall {
    0% {
        transform: translateY(-100px);
        opacity: 1;
    }
    100% {
        transform: translateY(100vh);
        opacity: 0;
    }
}

- falling-pixels.js

  • 픽셀을 생성하고, 랜덤한 위치와 애니메이션 지속 시간을 설정하는 JavaScript 코드를 작성한다.
  • 각 픽셀이 애니메이션이 끝난 후 제거되도록 하여 화면을 정리한다.
const pixelContainer = document.getElementById('pixel-container');

function createPixel() {
    const pixel = document.createElement('div');
    pixel.classList.add('pixel');

    // 수평 위치를 랜덤으로 설정
    pixel.style.left = `${Math.random() * 100}vw`;

    // 픽셀들이 서로 다른 속도로 떨어지도록 랜덤한 애니메이션 지속 시간을 설정
    pixel.style.animationDuration = `${5 + Math.random() * 2}s`;

    // 픽셀을 컨테이너에 추가
    pixelContainer.appendChild(pixel);

    // 애니메이션이 끝나면 픽셀을 제거
    pixel.addEventListener('animationend', () => {
        pixel.remove();
    });
}

// 일정 간격으로 새로운 픽셀을 생성
setInterval(createPixel, 500);

완성! (웹페이지 보면서 멍 때리기 가능)


- 결과물

 

Pixel Falling Animation

 

algo-gaja.github.io


 

728x90
반응형
'◈ Yermi Project/Toy Project💎' 카테고리의 다른 글
  • [Toy Project] 원영적 사고, Open AI로 뒷북 쳐보자😊 [Chat GPT에게 초긍정적 사고 학습시키기]
  • [Toy Project] 떨어지는 픽셀이 바닥에 쌓이는 애니메이션 구현하기 [CSS 애니메이션과 JavaScript 활용]
  • [Toy Project] URL 단축기를 만들어보자!✂️ [서버 구축하기 싫어서 DB는 Google Sheets로 대체]
  • [Toy Project] 식당 메뉴판 만들기🍖 (feat. CORS의 늪에 빠지다.) [axios, iframe 등을 활용한 네이버 블로그 스크랩핑 시도]
예르미(yermi)
예르미(yermi)
끊임없이 제 자신을 계발하는 개발자입니다👨🏻‍💻
  • 예르미(yermi)
    예르미의 코딩노트
    예르미(yermi)
  • 전체
    오늘
    어제
    • 분류 전체보기 (987)
      • ◎ Java (133)
        • Java☕ (93)
        • JSP📋 (26)
        • Applet🧳 (6)
        • Interview👨🏻‍🏫 (8)
      • ◎ JavaScript (48)
        • JavaScript🦎 (25)
        • jQuery🌊 (8)
        • React🌐 (2)
        • Vue.js🔰 (6)
        • Node.js🫒 (3)
        • Google App Script🐑 (4)
      • ◎ HTML5+CSS3 (17)
        • HTML5📝 (8)
        • CSS3🎨 (9)
      • ──────────── (0)
      • ▣ Framework (67)
        • Spring🍃 (36)
        • Spring Boot🍀 (12)
        • Bootstrap💜 (3)
        • Selenium🌕 (6)
        • MyBatis🐣 (10)
      • ▣ Tools (47)
        • API🎯 (18)
        • Library🎲 (15)
        • JitPack🚀 (3)
        • Jenkins👨🏻 (7)
        • Thymeleaf🌿 (4)
      • ▣ Server (30)
        • Apache Tomcat🐱 (14)
        • Apache HTTP Server🛡️ (1)
        • Nginx🧶 (7)
        • OracleXE💿 (4)
        • VisualSVN📡 (4)
      • ▣ Infra & DevOps (5)
        • LGTM Stack🔭 (5)
      • ▣ OS : 운영체제 (18)
        • cmd : 명령프롬프트💻 (10)
        • Linux🐧 (8)
      • ▣ SQL : Database (56)
        • Oracle SQL🏮 (26)
        • PL SQL💾 (9)
        • MySQL🐬 (6)
        • MariaDB🦦 (6)
        • H2 Database🔠 (3)
        • SQL 실전문제🐌 (6)
      • ────────── (0)
      • ◈ Human Project (86)
        • Mini : Library Service📚 (15)
        • 화면 설계 [HTML]🐯 (10)
        • 서버 프로그램 구현🦁 (15)
        • Team : 여수어때🛫 (19)
        • Custom : Student🏫 (9)
        • Custom : Board📖 (18)
      • ◈ Yermi Project (40)
        • 조사모아(Josa-moa)📬 (5)
        • Riddle-Game🧩 (6)
        • 맛있을 지도🍚 (2)
        • 어디 가! 박대리!🙋🏻‍♂️ (5)
        • 조크베어🐻‍❄️ (4)
        • Looks Like Thirty🦉 (2)
        • Toy Project💎 (12)
        • 오픈소스 파헤치기🪐 (4)
      • ◈ Refactoring (15)
        • Mini : Library Service📚 (8)
        • 서버 프로그램 구현🦁 (1)
        • Team : 여수어때🛫 (0)
        • 쿼리 튜닝일지🔧 (6)
      • ◈ Coding Test (80)
        • 백준(BOJ)👨🏻‍💻 (71)
        • 프로그래머스😎 (2)
        • 코드트리🌳 (7)
      • ◈ Study (129)
        • 기초튼튼 개발지식🥔 (25)
        • HTTP 웹 지식💡 (4)
        • 클린코드(Clean Code)🩺 (1)
        • 디자인패턴(GoF)🥞 (12)
        • 알고리즘(Algorithm)🎡 (14)
        • 다이어그램(Diagram)📈 (4)
        • 파이썬(Python)🐍 (16)
        • 에러노트(Error Note)🧱 (34)
        • 웹 보안(Web Security)🔐 (11)
        • 인공지능 AI🛸 (8)
      • ◈ 공부모임 (55)
        • 혼공학습단⏰ (18)
        • 코드트리 챌린지👊🏻 (2)
        • 개발도서 100독👟 (8)
        • 나는 리뷰어다🌾 (15)
        • 국가기술자격 서포터즈🌻 (12)
      • ◈ 자격증 공부 (37)
        • 정보처리기사🔱 (16)
        • 정보처리산업기사🔅 (9)
        • 정보보안기사⚜️ (0)
        • 컴퓨터활용능력 1급📼 (12)
      • ─────────── (0)
      • ◐ 기타 (124)
        • 알아두면 좋은 팁(tip)✨ (46)
        • 개발자의 일상🎈 (55)
        • 개발도서 서평🔍 (10)
        • 개발관련 세미나🎤 (2)
        • 블로그 꾸미기🎀 (9)
        • 사도신경 프로젝트🎚️ (2)
  • 인기 글

  • 최근 댓글

  • 반응형
    250x250
  • 태그

    jsp
    BOJ
    Oracle
    꿀팁
    자바스크립트
    Database
    html
    Error Note
    코딩 테스트
    javascript
    일상
    백준
    Java
    Project
    spring
    SQL
    CSS
    프로그래밍
    코딩
    백준 티어
  • hELLO· Designed By정상우.v4.10.3
예르미(yermi)
[Toy Project] 웹페이지에서 랜덤한 픽셀 떨어뜨리기 애니메이션 구현하기 [CSS 애니메이션과 JavaScript 활용]
상단으로

티스토리툴바