간편결제, 신용카드 청구할인
인터파크 롯데카드 5% (29,930원)
(최대할인 10만원 / 전월실적 40만원)
북피니언 롯데카드 30% (22,050원)
(최대할인 3만원 / 3만원 이상 결제)
NH쇼핑&인터파크카드 20% (25,200원)
(최대할인 4만원 / 2만원 이상 결제)
Close

Three.js로 3D 그래픽 만들기 : WebGL을 위한 자바스크립트 3D 라이브러리[초판]

원제 : Learning Three.js: the JavaScript 3D Library for WebGL: Create stunning 3D graphics in your browser using the Three.js JavaScript library(2nd ed.)
소득공제

2013년 9월 9일 이후 누적수치입니다.

판매지수 35
?
판매지수란?
사이트의 판매량에 기반하여 판매량 추이를 반영한 인터파크 도서에서의 독립적인 판매 지수입니다. 현재 가장 잘 팔리는 상품에 가중치를 두었기 때문에 실제 누적 판매량과는 다소 차이가 있을 수 있습니다. 판매량 외에도 다양한 가중치로 구성되어 최근의 이슈도서 확인시 유용할 수 있습니다. 해당 지수는 매일 갱신됩니다.
Close
공유하기
정가

35,000원

  • 31,500 (10%할인)

    1,750P (5%적립)

할인혜택
적립혜택
  • I-Point 적립은 마이페이지에서 직접 구매확정하신 경우만 적립 됩니다.
추가혜택
배송정보
  • 2/1(수) 이내 발송 예정  (서울시 강남구 삼성로 512)
  • 무료배송
주문수량
감소 증가
  • 이벤트/기획전

  • 연관도서(241)

  • 상품권

AD

책소개

최신 브라우저는 플래시나 자바 같은 플러그인 없이도 브라우저에서 3D 그래픽을 생성할 수 있는 웹지엘(WebGL)을 지원한다. 하지만 웹지엘 프로그래밍은 어렵고 복잡하며, 디버깅도 어렵다. Three.js를 사용하면 웹지엘을 몰라도 자바스크립트를 이용해 직관적으로 멋진 3D 그래픽을 작성할 수 있다. Three.js를 사용해 모든 브라우저에서 동작하는 3D 애니메이션 그래픽을 만드는 데 필요한 모든 것을 풍부한 실전 예제와 함께 알아볼 것이다..

출판사 서평

★ 이 책에서 다루는 내용 ★

■ Three.js가 제공하는 다양한 지오메트리 사용
■ 3D 장면에 사실적인 조명과 그림자 적용
■ Three.js가 제공하는 다양한 카메라 컨트롤을 사용해 3D 장면 탐색
■ 범프 맵과 노멀 맵, 반사 맵, 라이트 맵의 고급 텍스처를 사용한 사실적인 3D 객체 생성
■ OBJ와 STL, 콜라다 같은 외부 포맷의 모델 가져오기와 애니메이션
■ 모프 타겟과 스켈레톤 애니메이션을 이용한 애니메이션 생성
■ Physijs 자바스크립트 라이브러리로 3D 장면에 물리 적용
■ 사용자 정의 꼭지점 셰이더와 프레그먼트 셰이더를 작성해 웹지엘과 직접 상호작용

★ 이 책의 대상 독자 ★

이미 자바스크립트에 대해 알고 있으면서 모든 브라우저에서 실행되는 3D 그래픽을 만들고 싶어 하는 사람들을 위한 책이다. 고급 수학이나 웹지엘에 대한 지식이 없어도 좋다. 자바스크립트와 HTML에 대한 일반적인 지식만 있으면 충분하다. 이 책에서 사용된 모든 도구는 오픈소스며 필요한 자원과 예제는 자유롭게 다운로드할 수 있다. 오늘날의 모든 브라우저에서 실행되는 아름다운 대화형 3D 그래픽을 만들고 싶다면, 이 책이 많은 도움이 될 것이다.

★ 이 책의 구성 ★

1장, ‘Three.js로 첫 번째 3D 장면 제작’에서는 Three.js 시작에 필요한 기본 단계를 설명한다. 1장을 마치면 첫 번째 Three.js 장면을 만들고 브라우저에서 첫 3D 장면을 실행시킬 수 있게 될 것이다.

2장, ‘Three.js 장면의 기본 구성요소’에서는 Three.js로 작업하는 데 필요한 기본 구성요소에 대해 설명한다. 조명과 메시, 지오메트리, 물질 및 카메라에 대해 알아본다. 또한 2장을 통해 Three.js가 제공하는 다양한 조명과 장면에서 사용할 수 있는 카메라에 대한 개요를 배운다.

3장, ‘Three.js에서 사용할 수 있는 다양한 광원’에서는 장면에서 사용할 수 있는 다양한 조명에 대해 자세히 알아본다. 예제를 통해 스포트라이트, 방향 조명, 주변광, 점 조명, 반구 조명 및 지역 조명에 대해 설명한다. 또한 광원에 렌즈 플레어 효과를 적용하는 방법을 설명한다.

4장, ‘Three.js 물질로 작업’에서는 메시에 사용할 수 있는 Three.js의 물질에 대해 살펴본다. 물질을 구성할 때 설정할 수 있는 모든 속성을 알아보고 대화형 예제를 통해 Three.js에서 사용할 수 있는 물질을 실험해 볼 수 있다.

5장, ‘지오메트리로 작업’에서는 Three.js가 제공하는 모든 지오메트리에 대해 알아보는 두 개의 장 중 첫 번째 장이다. 이 장에서는 Three.js에서 지오메트리를 구성하고 생성하는 방법을 설명한다. 또한 대화형 예제를 통해 평면, 원, 형상, 정육면체, 실린더, 토러스, 토러스 매듭, 다면체 같은 지오메트리를 실험해 본다.

6장, ‘고급 지오메트리와 이항 연산’에서는 5장에 이어 지오메트리를 알아본다. Three.js가 제공하는 콘벡스(Convex)와 레이드(Lathe) 같은 Three.js의 고급 지오메트리를 구성하는 방법을 알아본다. 또한 2D 형상에서 3D 형상을 압출하는 방법과 이항 연산으로 지오메트리를 결합해 새로운 지오메트리를 만드는 방법을 배운다.

7장, ‘파티클과 스프라이트, 포인트 클라우드’에서는 Three.js에서 포인트 클라우드를 사용하는 방법을 설명한다. 새롭게 또는 기존 지오메트리에서 포인트 클라우드를 만드는 방법을 배운다. 또한 스프라이트와 포인트 클라우드 물질을 사용해 개별 포인트의 모습을 변경하는 방법도 살펴본다.

8장, 고급 메시와 지오메트리의 생성과 로딩 외부 소스에서 메시와 지오메트리를 가져오는 방법과 Three.js의 내부 JSON 포맷을 사용해 지오메트리와 장면을 저장하는 방법을 알아본다. 이 장에서는 또한 OBJ와 DAE, STL, CTM, PLY 같은 파일 포맷에서 모델을 로드하는 방법을 설명한다.

9장, 애니메이션과 카메라 이동 장면을 살아있게 만드는 데 사용할 수 있는 다양한 형태의 애니메이션을 알아본다. Three.js와 함께 Tween.js 라이브러리를 사용하는 방법과 모피(morph) 타깃과 스켈레톤(skeleton) 애니메이션 모델로 작업하는 방법을 설명한다.

10장, 텍스처 로딩과 작업 4장에서 배운 물질을 확장해 텍스처에 대해 자세히 알아본다. 이 장에서는 사용 가능한 다양한 텍스처를 소개하고 어떻게 메시에 적용하는 방법을 제어하는 지 살펴본다. 또한 HTML5 video와 canvas 요소의 출력을 직접 텍스처의 입력으로 사용하는 방법을 알아본다.

11장, 사용자 정의 셰이더와 렌더링 후처리 Three.js로 렌더링된 장면에 후처리 효과를 적용하는 방법을 알아본다. 후처리로 렌더링된 장면에 블러(blur)나 틸트시프트(tiltshift), 세피아 (sepia) 같은 효과를 적용할 수 있다. 이 외에도 자신만의 후처리 효과와 사용자 정의 꼭지점 셰이더, 프레그먼트 셰이더를 만드는 방법을 알아본다.

12장, 장면에 물리 이론과 사운드 추가 Three.js 장면에 물리 이론을 추가하는 방법을 알아본다. 물리 이론으로 객체 사이의 충돌을 발견하거나 중력에 반응하게 만들고, 마찰을 적용할 수 있다. 이 장에서는 Physijs 물리 엔진을 사용하는 방법을 설명한다. 또한 Three.js 장면에 위치 오디오를 추가하는 방법을 알아본다.

목차

1 Three.js로 첫 번째 3D 장면 제작
__Three.js 사용에 필요한 요구사항
__소스 코드 가져오기
____깃을 사용해 저장소 복제
____아카이브를 다운로드하고 추출
____예제 테스트
________대부분의 유닉스/맥 시스템에서 동작하는 파이썬 기반의 웹 서버
________Node.js로 작업하는 경우의 npm 기반 웹 서버
________맥 또는 윈도우용 몽구스 포터블 버전
________파이어폭스와 크롬에서의 보안 설정 비활성화
__HTML 스켈레톤 생성
__3D 객체의 렌더링과 표시
__물질과 광원, 그림자 추가
__애니메이션으로 장면 개선
____requestAnimationFrame 소개
____정육면체 애니메이션
____공 바운싱
__dat.GUI로 실험을 쉽게 만든다
__브라우저 크기 변경에 따라 자동으로 결과물의 크기 조정
__요약

2 Three.js 장면의 기본 구성요소
__장면 작성
____장면의 기본 기능
____장면에 안개 추가
____overrideMaterial 속성 사용
__지오메트리와 메시
____지오메트리의 속성과 함수
____메시용 함수와 속성
__두 가지 카메라의 사용
____직교카메라 대 원근카메라
____특정 지점을 바라보기
__요약

3 Three.js에서 사용할 수 있는 다양한 광원
__Three.js가 제공하는 다양한 빛
__기본 광원
____THREE.AmbientLight
________THREE.Color 객체 사용
____THREE.PointLight
____THREE.SpotLight
____THREE.DirectionalLight
__특수 광원
____THREE.HemisphereLight
____THREE.AreaLight
____LensFlare
__요약

4 Three.js 물질로 작업
__물질의 공통 속성
____기본 속성
____브렌딩 속성
____고급 속성
__간단한 메시부터 시작
____THREE.MeshBasicMaterial
____THREE.MeshDepthMaterial
____물질의 결합
____THREE.MeshNormalMaterial
____THREE.MeshFaceMaterial
__고급 물질
____THREE.MeshLambertMaterial
____THREE.MeshPhongMaterial
____THREE.ShaderMaterial로 자신만의 셰이더 제작
__라인 지오메트리에서 사용할 수 있는 물질
____THREE.LineBasicMaterial
____THREE.LineDashedMaterial
__요약

5 지오메트리로 작업
__Three.js가 제공하는 기본 지오메트리
____2D 지오메트리
________THREE.PlaneGeometry
________THREE.CircleGeometry
________THREE.RingGeometry
________THREE.ShapeGeometry
____3D 지오메트리
________THREE.BoxGeometry
________THREE.SphereGeometry
________THREE.CylinderGeometry
________THREE.TorusGeometry
________THREE.TorusKnotGeometry
________THREE.PolyhedronGeometry
__요약

6 고급 지오메트리와 이항 연산
__THREE.ConvexGeometry
__THREE.LatheGeometry
____압출로 지오메트리 생성
________THREE.ExtrudeGeometry
________THREE.TubeGeometry
________SVG에서 압출
________THREE.ParmametricGeometry
__3D 텍스트 생성
____텍스트 렌더링
____사용자 정의 폰트 추가
__이항 연산으로 메시 결합
____subtract 함수
____intersect 함수
____union 함수
__요약

7 파티클과 스프라이트, 포인트 클라우드
__파티클의 이해
__파티클과 THREE.PointCloud, THREE.PointCloudMaterial
__HTML5 캔버스로 파티클에 스타일 주기
____HTML5 캔버스를 THREE.CanvasRenderer와 함께 사용
____HTML5 캔버스를 WebGLRenderer와 함께 사용
__텍스처로 파티클에 스타일 주기
__스프라이트 맵으로 작업
__고급 지오메트리에서 THREE.PointCloud 제작
__요약

8 고급 메시와 지오메트리의 생성과 로딩
__지오메트리의 그룹화와 병합
____객체의 그룹화
__여러 메시를 병합해 하나의 메시 생성
__외부 자원에서 지오메트리 로딩
__Thee.js JSON 포맷으로 저장하고 로딩
____THREE.Mesh의 저장과 로딩
____장면의 저장과 로딩
__블렌더로 작업
__블렌더에 Three.js 익스포터 설치
____블렌더에서 모델을 로딩하고 내보내기
__3D 파일 포맷에서 가져오기
____OBJ와 MTL 포맷
____콜라다 모델의 로드
____STL과 CTM, VTK, AWD, Assimp, VRML, 바빌론 모델 로딩
____단백질 데이터 은행에서 가져온 단백질 구조 표시
____PLY 모델로 파티클 시스템 제작
__요약

9 애니메이션과 카메라 이동
__기본 애니메이션
____간단한 애니메이션
____객체 선택
____Tween.js를 이용한 애니메이션
__카메라를 이용한 작업
____TrackballControls
____FlyControls
____RollControls
____FirstPersonControls
____OrbitControl
__모핑과 스켈레탈 애니메이션
____모프 타깃으로 애니메이션
________MorphAnimMesh를 이용한 애니메이션
________morphTargetInfluence 속성으로 애니메이션 생성
____뼈대와 스키닝을 이용한 애니메이션
__외부 모델을 사용해 애니메이션 생성
________블렌더로 뼈대 애니메이션 생성
________콜라다 모델에서 애니메이션 로딩
________퀘이크 모델에서 애니메이션 로드
__요약

10 텍스처 로딩과 작업
__물질에서 텍스처 사용
____텍스처를 로딩하고 메시에 적용
____범프 맵을 사용해 주름 생성
____법선 맵으로 더 세밀한 범프와 주름 생성
____라이트 맵으로 페이크 그림자 생성
____환경 맵으로 페이크 반영 생성
____스페큘라 맵
__고급 텍스처 사용
____사용자 정의 UV 매핑
____래핑 반복
____캔버스에 렌더링하고 이를 텍스처로 사용
________캔버스를 텍스처로 사용
________캔버스를 범프 맵으로 사용
____비디오의 출력을 텍스처로 사용
__요약

11 사용자 정의 셰이더와 렌더링 후처리
__후처리를 위한 Three.js 설정
____THREE.EffectComposer
________후처리를 위한 THREE.EffectComposer 설정
________render 루프 업데이트
__후처리 패스
____간단한 후처리 패스
________THREE.FilePass를 사용해 TV 효과 생성
________THREE.BloomPass로 장면에 블룸 효과 추가
________장면을 점의 집합으로 출력
________동일 화면의 여러 렌더러의 결과 보기
____마스크를 사용한 고급 EffectComposer 흐름
____THREE.ShaderPass로 사용자 정의 효과 주기
________간단한 셰이더
________블러링 셰이더
________고급 셰이더
__사용자 정의 후처리 셰이더 생성
____사용자 정의 그레이스케일 셰이더
____사용자 정의 비트 셰이더 생성
__요약

12 장면에 물리 이론과 사운드 추가
__기본 Three.js 장면 제작
__물질 속성
__기본 지원 형상
__제약조건을 사용해 객체의 움직임 제한
____PointConstraint를 사용해 두 지점 사이의 움직임 제한
____HingeConstraint로 문 같은 제약조건 생성
____SliderConstraint로 움직임을 단일 축으로 제한
____ConeTwistConstraint로 구상관절 같은 제약조건 생성
____DOFConstraint로 상세한 제어 생성
____장면에 사운드 추가
__요약

저자소개

요스 디륵센 [저] 신작알림 SMS신청
생년월일 -

해당작가에 대한 소개가 없습니다.

류영선 [역] 신작알림 SMS신청
생년월일 -

해당작가에 대한 소개가 없습니다.

이 상품의 시리즈

(총 242권 / 현재구매 가능도서 242권)

선택한 상품 북카트담기
펼쳐보기

전공도서/대학교재 분야에서 많은 회원이 구매한 책

    리뷰

    10.0 (총 0건)

    100자평

    작성시 유의사항

    평점
    0/100자
    등록하기

    100자평

    0.0
    (총 0건)

    판매자정보

    • 인터파크도서에 등록된 오픈마켓 상품은 그 내용과 책임이 모두 판매자에게 있으며, 인터파크도서는 해당 상품과 내용에 대해 책임지지 않습니다.

    상호

    (주)교보문고

    대표자명

    안병현

    사업자등록번호

    102-81-11670

    연락처

    1544-1900

    전자우편주소

    callcenter@kyobobook.co.kr

    통신판매업신고번호

    01-0653

    영업소재지

    서울특별시 종로구 종로 1(종로1가,교보빌딩)

    교환/환불

    반품/교환 방법

    ‘마이페이지 > 취소/반품/교환/환불’ 에서 신청 또는 1:1 문의 게시판 및 고객센터(1577-2555)에서 신청 가능

    반품/교환가능 기간

    변심 반품의 경우 출고완료 후 6일(영업일 기준) 이내까지만 가능
    단, 상품의 결함 및 계약내용과 다를 경우 문제점 발견 후 30일 이내

    반품/교환 비용

    변심 혹은 구매착오로 인한 반품/교환은 반송료 고객 부담
    상품이나 서비스 자체의 하자로 인한 교환/반품은 반송료 판매자 부담

    반품/교환 불가 사유

    ·소비자의 책임 있는 사유로 상품 등이 손실 또는 훼손된 경우
    (단지 확인을 위한 포장 훼손은 제외)

    ·소비자의 사용, 포장 개봉에 의해 상품 등의 가치가 현저히 감소한 경우
    예) 화장품, 식품, 가전제품(악세서리 포함) 등

    ·복제가 가능한 상품 등의 포장을 훼손한 경우
    예) 음반/DVD/비디오, 소프트웨어, 만화책, 잡지, 영상 화보집

    ·시간의 경과에 의해 재판매가 곤란한 정도로 가치가 현저히 감소한 경우

    ·전자상거래 등에서의 소비자보호에 관한 법률이 정하는 소비자 청약철회 제한 내용에 해당되는 경우

    상품 품절

    공급사(출판사) 재고 사정에 의해 품절/지연될 수 있음

    소비자 피해보상
    환불지연에 따른 배상

    ·상품의 불량에 의한 교환, A/S, 환불, 품질보증 및 피해보상 등에 관한 사항은 소비자분쟁해결 기준 (공정거래위원회 고시)에 준하여 처리됨

    ·대금 환불 및 환불지연에 따른 배상금 지급 조건, 절차 등은 전자상거래 등에서의 소비자 보호에 관한 법률에 따라 처리함

    (주) 인터파크 안전결제시스템 (에스크로) 안내

    (주)인터파크의 모든 상품은 판매자 및 결제 수단의 구분없이 회원님들의 구매안전을 위해 안전결제 시스템을 도입하여 서비스하고 있습니다.
    결제대금 예치업 등록 : 02-006-00064 서비스 가입사실 확인

    배송안내

    • 교보문고 상품은 택배로 배송되며, 출고완료 1~2일내 상품을 받아 보실 수 있습니다.

    • 출고가능 시간이 서로 다른 상품을 함께 주문할 경우 출고가능 시간이 가장 긴 상품을 기준으로 배송됩니다.

    • 군부대, 교도소 등 특정기관은 우체국 택배만 배송가능합니다.

    • 배송비는 업체 배송비 정책에 따릅니다.

    • - 도서 구매 시, 1만 원 이상 무료, 1만원 미만 2천 원 - 상품별 배송비가 있는 경우, 상품별 배송비 정책 적용