18 lines
3.3 KiB
Markdown
18 lines
3.3 KiB
Markdown
# [[GPU 가속 및 컴포지팅]]
|
|
|
|
## 📌 Brief Summary
|
|
GPU 가속 및 컴포지팅은 브라우저의 메인 스레드에서 처리하던 애니메이션 작업을 기기의 GPU(그래픽 처리 장치)로 위임하여 웹 성능을 크게 향상시키는 기술입니다 [1]. 이 기법을 사용하면 비용이 많이 드는 브라우저의 레이아웃(Reflow) 및 페인트(Repaint) 단계를 건너뛰고, 오직 컴포지트(Composite) 단계만을 실행하여 렌더링 부담을 줄일 수 있습니다 [2]. 특히 모바일 기기나 저사양 환경에서도 초당 60프레임(60 FPS)의 매끄러운 애니메이션을 달성하는 데 핵심적인 역할을 합니다 [2-4].
|
|
|
|
## 📖 Core 단락
|
|
* **픽셀 파이프라인과 컴포지트 단계:** DOM 요소가 변경될 때 브라우저는 '스타일 재계산 -> 레이아웃(Reflow) -> 페인트(Repaint) -> 컴포지트(Composite)'로 이어지는 픽셀 파이프라인을 실행합니다 [5]. 애니메이션 성능을 극한으로 끌어올리기 위해서는 전체 파이프라인을 다시 거치지 않고, 마지막 컴포지트 단계만을 유발하는 속성을 사용하는 것이 중요합니다 [2].
|
|
* **GPU 가속을 유발하는 속성:** 브라우저가 특정 애니메이션을 자동으로 GPU로 보내도록 만들 수 있습니다 [1]. 대표적으로 `transform`과 `opacity` 속성이 이를 지원하며, 리플로우나 리페인트 없이 GPU 가속을 통해 애니메이션을 처리합니다 [2, 6, 7]. 추가로 `transform: translateZ()`나 `rotate3d()` 같은 3D 변환, `position: fixed`, 그리고 `will-change` 속성이 적용된 요소나 `<video>`, `<canvas>`, `<iframe>` 요소 등도 자체적인 레이어에서 렌더링되어 컴포지팅의 이점을 얻습니다 [3].
|
|
* **사용 시 주의사항:** 모든 속성이 가속을 통해 이점을 얻는 것은 아닙니다. `box-shadow`, `filter`, `border-radius`와 같은 속성들은 애니메이션 시 컴포지팅 레이어나 블렌딩 과정에서 추가적인 리소스를 요구하여 오히려 애니메이션을 느리게 만들 수 있습니다 [6]. 또한 `will-change` 속성은 브라우저가 변경 사항을 미리 최적화하도록 돕지만, 너무 많은 요소에 남용할 경우 도리어 성능을 저하시킬 수 있습니다 [8].
|
|
* **성능 프로파일링 및 디버깅:** CSS 애니메이션이 올바르게 최적화되었는지 확인하려면 Chrome DevTools를 활용할 수 있습니다. 특히 Layer Profiler를 사용하면 어떤 요소가 복합 레이어(Composite layer)에서 렌더링되고 있는지 식별하여 성능 병목 현상을 파악할 수 있습니다 [9].
|
|
|
|
## 🔗 Knowledge Connections
|
|
- **Related Topics:** CSS 애니메이션 성능 최적화, Reflow와 Repaint (리플로우와 리페인트), transform 및 opacity 속성, will-change 속성
|
|
- **Projects/Contexts:** 모바일 우선 및 저사양 기기를 고려한 웹 성능 최적화, 60 FPS의 부드러운 상호작용 및 애니메이션 구현
|
|
- **Contradictions/Notes:** 컴포지팅은 애니메이션 성능 최적화의 핵심이지만, `box-shadow`나 `filter` 등의 속성을 포함한 애니메이션은 무거운 렌더링 과정을 유발해 오히려 성능 저하를 초래할 수 있으므로 주의해야 합니다 [6].
|
|
|
|
---
|
|
*Last updated: 2026-04-26* |