기타 학습/기획, UI, UX

[Three.js] npm을 이용해 Mac에 설치, Visual Studio Code로 실행해보기!

Kangjieun11 2024. 3. 6. 00:07
728x90

 

✅  선행개념

three.js의 개념과 핵심객체 (Renderer, Scene, Camera)

 

https://jie0025.tistory.com/614

 

[three.js] 3D를 웹에 렌더링하는 라이브러리 (개념 & 핵심 객체 Renderer, Scene, Camera)

three.js Web 상에서 3D를 띄울 수 있는 Javascript 라이브러리 중 하나 * 선행개념으로 html, css, Javascript가 있다. ✅ 장점 가장 인기 있는 라이브러리 중 하나로, WebGL 작업 프로세스를 단순화했다. 플러

jie0025.tistory.com

 

 


 

 

✅  npm을 이용해 three.js 설치하기

 

터미널에서 npm을 이용해

three.js 를 아주 간단하게 설치할 수도 있다. 

 

만약 npm이 없다면 npm 설치 까지 해버리자.

 

 

* 타블로그 NPM 설치 글

https://code-algo.tistory.com/126#google_vignette

 

 

 

 

✔️ 터미널에 아래 명령 입력

npm install three

 

'

 

⏺ three.js 공간 테스트

 

폴더를 하나 만들고,

Visual Studio 로 접속, index.html 파일을 생성했다.

 

 

 

 

지금 당장은  index.html에 아래 코드 입력한 후  테스트만 진행해보자

상세한 내용은 이후에 더 디테일하게 설명하겠다 :)

<!DOCTYPE html>
<html>
	<head>
		<meta charset="utf-8">
		<title>My first three.js app</title>
		<style>
			body { margin: 0; }
			canvas { display: block; }
		</style>
	</head>
	<body>
		<script type="module">
			import * as THREE from 'https://unpkg.com/three/build/three.module.js';

			const scene = new THREE.Scene();
			const camera = new THREE.PerspectiveCamera( 75, window.innerWidth / window.innerHeight, 0.1, 1000 );

			const renderer = new THREE.WebGLRenderer();
			renderer.setSize( window.innerWidth, window.innerHeight );
			document.body.appendChild( renderer.domElement );

			const geometry = new THREE.BoxGeometry( 1, 1, 1 );
			const material = new THREE.MeshBasicMaterial( { color: 0x00ff00 } );
			const cube = new THREE.Mesh( geometry, material );
			scene.add( cube );

			camera.position.z = 5;

			function animate() {
				requestAnimationFrame( animate );

				cube.rotation.x += 0.01;
				cube.rotation.y += 0.01;

				renderer.render( scene, camera );
			}

			animate();
		</script>
	</body>
</html>

 

 

 

 

 

Open in Default Browser 를 클릭해보면 

아래와 같이 정상적으로 화면에 3D 객체가 렌더링되는것을 확인할 수 있다.

굿

 

 

 


 

 

 

✅ 자바스크립트 코드 상세 설명

 

 

//01: Scene 장면 생성
const scene = new THREE.Scene();
            
//02: Camera 생성                     
const camera = new THREE.PerspectiveCamera( 75, window.innerWidth / window.innerHeight, 0.1, 1000 );

//03: Renderer 생성
const renderer = new THREE.WebGLRenderer();
renderer.setSize( window.innerWidth, window.innerHeight );
            
//04: renderer를 body태그 밑에 element로 추가
document.body.appendChild( renderer.domElement );


//05: 장면(Scene) 내부에 실제로 들어갈 객체 생성 후 추가 
const geometry = new THREE.BoxGeometry( 1, 1, 1 );
const material = new THREE.MeshBasicMaterial( { color: 0x00ff00 } );
const cube = new THREE.Mesh( geometry, material );
scene.add( cube );

//06: 카메라의 위치 설정 (x,y,z축 설정 가능)
camera.position.z = 5;
			
//07: animate함수 정의  - 화면 렌더링과 cube 객체의 x, y가 0.01씩 움직이도록 설정 
function animate() {
            
    // 새로고침 될 때마다 계속해서 렌더링 해줌 (일반적으로 1초에 60번 렌더링)
    requestAnimationFrame( animate );

    cube.rotation.x += 0.01;
    cube.rotation.y += 0.01;

    renderer.render( scene, camera );
}

animate();

 

 

 

 

오늘은 간단하게 three.js를 설치하고 동작시켜 보았다.

 

다음엔 cube와 같이 도형(객체)에 더 다양한 효과를 넣는것을 알아보도록 하자.

 

 


 

References

https://threejs.org/docs/#manual/ko/introduction/Installation

https://threejs.org/docs/#manual/ko/introduction/Creating-a-scene