ThreeJS 에서 텍스처 변경 및 업데이트 방법 - 노말 맵, 텍스처 맵, displacement 맵 - Whitmem
ThreeJS 에서 텍스처 변경 및 업데이트 방법 - 노말 맵, 텍스처 맵, displacement 맵
Graphic Development
2025-01-02 22:17 게시 eb7cfaa090ffb37c6916

0
0
36
이 페이지는 외부 공간에 무단 복제할 수 없으며 오직 있는 그대로 게시되며 부정확한 내용을 포함할 수 있습니다. 법률이 허용하는 한 가이드 라인에 맞춰 게시 내용을 인용하거나 출처로 표기할 수 있습니다.
This page is not to be distributed to external services; it is provided as is and may contain inaccuracies.
텍스처 변경 및 업데이트를 하기 위해서
Material의 map 또는 normalMap 등에 Texture 을 적용한 뒤 needsUpdate 을 활성화한다.
텍스처를 로드하기 위해서는 THREE 내 TextureLoader 클래스를 사용하면 된다.
let textureLoader = new THREE.TextureLoader(); this.__normalPaper = textureLoader.load("data.jpg");
상기 소스코드는 ./data.jpg 위치의 이미지를 텍스처 로더로부터 로드해 텍스처 객체를 this.__normalPaper 에 담는 코드이다. 이 때, 상기 로드는 우선 텍스처 객체를 할당하고, 데이터가 로드되면 해당 객체에 텍스처 정보를 삽입한다는 것에 유의해야 한다.
따라서 textureLoader 의 load() 함수에 콜백 함수를 넘길 수 있으며, 콜백 종류는 다음과 같다.
load( url, onLoad, onProgress, onError )
첫 번째 경로는 URL, 두 번째는 onLoad 콜백, 세 번째는 onProgress, 네 번째는 onError 콜백이다. Progress는 진행 정도를 나타내는 콜백이고, Error, onLoad 를 통해 실패, 성공 여부를 파악할 수 있다. 성공 콜백함수를 통해 텍스처 로드가 성공되었을 때 해당 맵을 메트리얼에 적용하고 업데이트를 요청할 수 있다.
material.normalMap = this.__normalPaper; material.needsUpdate=true;
material 에 적용 가능한 대표적인 맵 종류는, 일반 텍스처인 map, 법선 텍스처인 normalMap 및 displacement 텍스처인 displacementMap을 적용할 수 있다.
material.map= this.__paperTexture material.normalMap = this.__normalPaperTexture; material.displacementMap = this.__displacePaperTexture;
댓글 0개
댓글은 일회용 패스워드가 발급되며 사이트 이용 약관에 동의로 간주됩니다.
확인
Whitmemit 개인 일지 블로그는 개인이 운영하는 정보 공유 공간으로 사용자의 민감한 개인 정보를 직접 요구하거나 요청하지 않습니다. 기본적인 사이트 방문시 처리되는 처리 정보에 대해서는 '사이트 처리 방침'을 참고하십시오. 추가적인 기능의 제공을 위하여 쿠키 정보를 사용하고 있습니다. Whitmemit 에서 처리하는 정보는 식별 용도로 사용되며 기타 글꼴 및 폰트 라이브러리에서 쿠키 정보를 사용할 수 있습니다.
이 자료는 모두 필수 자료로 간주되며, 사이트 이용을 하거나, 탐색하는 경우 동의로 간주합니다.