Frontend

[Three] 01. Three.js 기본 구성 요소 - Renderer, Scene, Camera

Rayi 2025. 5. 4. 10:28

Three.js는 3차원 입체 구조를 2차원 캔버스를 통해 사용자에게 보여주는 역할을 합니다.

Scene과 Camera, 그리고 Renderer

이를 위해서는 몇가지 요소가 필요합니다.

 

우선 보여줄 사물들을 담아 둘 특정한 공간(Scene)이 필요합니다.

 

그리고 이 공간을 사용자가 화면으로 볼 시야를 제공해줄 카메라(Camera)가 있어야 하고,

 

이 공간을 카메라에 비치는 2차원 이미지로 바꿔주는 기능(Renderer)까지 있어야 사용자가 3차원 공간을 볼 수 있습니다.

1. Scene

Scene은 3차원 물체들이 들어갈 공간 그 자체입니다.

 

미리 정의된 Scene( ) 객체를 통해 선언할 수 있습니다.

import * as THREE from 'three';

const scene = new THREE.Scene();

Scene에는 Camera를 포함하여 광원, 물체, 텍스트, 이미지 등을 포함시킬 수 있습니다.

// ... camera 선언
scene.add(camera);

// ... ambient light (광원) 선언
scene.add(ambientLight);

// ... glowMesh (물체) 선언
scene.add(glowMesh);

2. Camera

Camera는 사용자가 scene을 볼 시점을 제공합니다.

 

미리 정의된 Camera( ) 객체들(PerspectiveCamera 등)을 통해 선언할 수 있습니다.

const camera = new THREE.PerspectiveCamera(
    60, // fov
    window.innerWidth / window.innerHeight, // aspect
    0.5, // near
    100 // far
);

3. Renderer

Renderer는 scene이 출력될 화면에 관한 설정을 수행합니다.

 

Scene을 그릴 canvas요소를 지정함으로서 선언할 수 있습니다.

import * as THREE from 'three';

const renderer = new THREE.WebGLRenderer({
    canvas,
    antialias: true
});

Renderer에서는 화면 크기, pixel ratio, 그림자 처리 등을 다룰 수 있습니다.

// 화면 크기

renderer.setSize(window.innerWidth, window.innerHeight);
// pixel ratio

renderer.setPixelRatio(window.devicePixelRatio > 1 ? 2: 1);

// 그림자
renderer.shadowMap.enabled = true;

마지막에는 render( ) 함수를 통해 실제로 랜더링을 진행해주어야 합니다.

renderer.render(scene, camera);

renderer.setAnimationLoop(draw);
728x90