본문내용 바로가기
무료배송 이벤트 소득공제

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

acorn+PACKT 시리즈
요스 디륵센 지음 | 류영선 옮김 | 에이콘출판 | 2016년 04월 28일 출간
  • 정가 : 35,000원
    판매가 : 31,500 [10%↓ 3,500원 할인]
  • 통합포인트 :
    [기본적립] 1,750원 적립 [5% 적립] 안내 [추가적립] 5만원 이상 구매 시 2천원 추가적립 [회원혜택] 우수회원 3만원 이상 구매 시 2~4% 추가적립
  • 추가혜택 : 포인트 안내 도서소득공제 안내 추가혜택 더보기
  • 배송비 : 무료 배송비 안내
  • 배송일정 : 서울특별시 종로구 세종대로 기준 지역변경
    지금 주문하면 내일(21일,화) 도착 예정 배송일정 안내
  • 바로드림 : 인터넷으로 주문하고 매장에서 직접 수령 안내 바로드림 혜택
    휴일에는 바로드림 픽업으로 더 빨리 받아 보세요. 바로드림 혜택받고 이용하기

이 책의 이벤트 해외주문/바로드림/제휴사주문/업체배송건의 경우 1+1 증정상품이 발송되지 않습니다.

  • 에이콘의 도서를 한 눈에 살펴보세요
    2017.11.23 ~ 2020.12.31
  • 게임/아트북을 한 눈에 모아보세요!
    2017.10.20 ~ 2020.12.31
  • MANNING, O'REILLY, PACKT, WILE..
    2016.03.07 ~ 2020.12.31
상품상세정보
ISBN 9788960778542(8960778540)
쪽수 436쪽
크기 188 * 235 * 23 mm /827g 판형알림
이 책의 원서/번역서 Learning Three.js: the JavaScript 3D Library for WebGL: Create stunning 3D graphics in your browser/Dirksen, Jos

책소개

이 책이 속한 분야

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

이 책의 총서

총서 자세히 보기

저자소개

저자 : 요스 디륵센

저자 요스 디륵센(Jos Dirksen)은 십 년 이상 소프트웨어 개발자 및 아키텍처로 일했다. 자바와 스칼라 같은 백엔드 기술부터, HTML5와 CSS, 자바스크립트 같은 프론트엔드 개발에 이르기까지 폭넓은 범위의 기술 개발에 많은 경험이 있다. 이 외에도, 정기적으로 컨퍼런스에서 연설하고 자신의 블로그에 새롭고 흥미로운 기술에 대해 쓰는 것을 좋아한다. 또한 새로운 기술을 실험하고 어떻게 하면 그 결과를 아름답게 시각화할 수 있는지에 관심이 많다. 연구 결과는 블로그(http://www.smartjava.org/)에서 확인할 수 있다.
현재 네덜란드 금융기관에서 컨설턴트로 일하고 있으며, 네덜란드의 대형 교육자료 출판사인 맘버그(Malmberg)에서 엔터프라이즈 아키텍처 역할도 수행했다. 그곳에서 1차, 2차, 그리고 직업 교육용 콘텐츠의 제작 및 출판을 위한 새로운 디지털 플랫폼을 만드는 데 도움을 주었다. 그전에는 필립스와 ASML 같은 민간기업에서 국방부 같은 공공기관에 이르기까지 다양한 분야에서 여러 역할을 수행했다.
이 책 외에도 Three.js의 가장 중요한 기능을 예제로 설명하는 『Three.js Essentials』와 예제를 기반으로 Three.js의 중요한 유스케이스를 커버하는 『Three.js Cookbook』이란 두 권의 책을 썼다.
프론트엔드 자바스크립트와 HTML5 기술 외에도, REST와 전통적인 웹 서비스 기반의 백엔드 서비스 개발에도 관심이 있다.

역자 : 류영선

역자 류영선은 소프트웨어 엔지니어로서 오랫동안 웹 브라우저와 웹 서버를 개발했다. 그 경험을 바탕으로 현재는 W3C 및 다양한 국제 표준화 단체에서 웹과 관련된 표준화 업무를 담당하고 있다. 최근에는 웹 기술을 PC에서 벗어나 모바일이나 DTV, 디지털 사이니지(Digital Signage), 웨어러블(Wearable), 오토모티브(Automotive) 등 다양한 IoT 디바이스에 접목하는 오픈 웹 플랫폼(Open Web Platform)에 관심을 가지고 관련 기술을 계속 연구 중이다. 또한 워크숍이나 세미나 강연 등을 통해 기술 전파에 힘쓰고 있다. 에이콘출판사에서 펴낸 『반응형 웹 디자인』(2012)과 『실전 예제로 배우는 반응형 웹 디자인』(2014), 『HTML5 웹소켓 프로그래밍』(2014), 『WebRTC 프로그래밍』(2015)을 번역했다.

작가의 말

지난 몇 년간 브라우저는 복잡한 애플리케이션과 그래픽을 제공할 수 있는 더 강력한 플랫폼으로 성장해 왔다. 대부분의 최신 브라우저들은 웹지엘(WebGL)을 채택했다. 웹지엘로 브라우저에서 아름다운 2D 애플리케이션과 그래픽을 만들 수 있을 뿐만 아니라, GPU를 사용해 아름답고 성능 좋은 3D 애플리케이션까지 만들 수 있게 되었다.
하지만 웹지엘로 직접 프로그래밍하는 것은 매우 복잡하다. 웹지엘의 내부를 상세히 이해하고 복잡한 셰이더 언어를 배워야 한다. Three.js는 웹지엘의 기능을 아주 쉽게 사용할 수 있는 자바스크립트 API를 제공해 웹지엘을 배우지 않고도 아름다운 3D 그래픽을 만들 수 있게 해준다.
Three.js는 브라우저에서 직접 3D 장면을 만드는 데 사용할 수 있는 많은 기능과 API를 제공한다. 이 책에서 제공하는 대화형 예제와 샘플 코드를 통해 Three.js가 제공하는 다양한 API를 배울 수 있다. - 저자 요스 디륵센

Three.js는 웹지엘을 쉽게 사용할 수 있게 해 주는 자바스크립트 라이브러리다. 플러그인 없이 웹 브라우저만으로 동작하는 고품질의 3D 그래픽을 구현할 수 있게 해 주는 웹지엘 1.0 규격이 발표된 것이 2011년이지만 웹지엘이 제공해주는 무궁한 가능성에 비해 실제 구현이 많지 않은 것이 사실이다. 이는 직접 웹지엘 장면을 제작하기 위해서는 많은 작업과 3D 그래픽에 대한 이해가 필요하기 때문이 아닐까 싶다.
Three.js는 이런 작업을 쉽게 해 주는 강력한 프레임워크다. 책에서 제공하는 풍부한 예제를 따라 하다 보면 웹 브라우저만으로 이렇게 멋지고 화려한 3D 그래픽을 쉽게 제공할 수 있다는 사실에 놀라게 될 것이다.
이제 브라우저만 있으면 많은 작업들이 가능해졌다. 브라우저로 디바이스를 직접 제어하고 네이티브 애플리케이션에 버금가는 웹 애플리케이션 개발이 가능할 뿐 아니라, 화상통신이나 웹소켓 같은 다양한 통신 방법의 제공, 2D 캔버스 그래픽을 이용한 게임도 지원 가능하다. 다음 단계는 3D 그래픽이 될 것이다. - 역자 류영선

목차

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로 상세한 제어 생성
____장면에 사운드 추가
__요약

출판사 서평

★ 이 책에서 다루는 내용 ★

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

북로그 리뷰 (1) 전체보기 쓰러가기

도서 구매 후 리뷰를 작성하시면 통합포인트를 드립니다.
결제 90일 이내 작성 시 300원 / 발송 후 5일 이내 작성시 400원 / 이 상품의 첫 리뷰 작성 시 500원
(포인트는 작성 후 다음 날 적립되며, 도서 발송 전 작성 시에는 발송 후 익일에 적립됩니다.
외서/eBook/음반/DVD/GIFT 및 잡지 상품 제외)
안내
  • three.js 입문서로 제격임 ic**ley | 2017-06-21 | 추천: 0 | 5점 만점에 5점 구매
    이 책은 three.js를 이용하여 3d 오브젝트를 웹에서 인터랙티브하게 구현하기 위한 기본서다. 인터넷에서 Three.js를 공부할 수도 있지만 아무래도 혼자 뿔뿔이 흩어져있는 지식을 찾아서 공부하기란 쉽지 않은 일이다. 그러기에 일단 이 책의 존재 자체에 감사함을 느낀다..ㅠ.ㅠ 나는 Cinema4D에서 만든 모델링을 three.js로 import하는 부분을 공부하기 위해 이 책을 구매했다. 첫 장에서 일단 3d 오브젝트를 만들고 조명과 카메라를 설정하고 애니메이션을 주는 등 전체 과정을 겪어볼 수 있게 만들었고, 그... 더보기

Klover 평점/리뷰 (0)

문장수집 (0) 문장수집 쓰기 나의 독서기록 보기
※구매도서의 문장수집을 기록하면 통합포인트 적립 안내

교환/반품/품절안내

※ 상품 설명에 반품/교환 관련한 안내가 있는 경우 그 내용을 우선으로 합니다. (업체 사정에 따라 달라질 수 있습니다.)

교환/반품/품절안내
반품/교환방법 마이룸 > 주문관리 > 주문/배송내역 > 주문조회 > 반품/교환신청 ,
[1:1상담>반품/교환/환불] 또는 고객센터 (1544-1900)

※ 오픈마켓, 해외배송주문, 기프트 주문시 [1:1상담>반품/교환/환불]
    또는 고객센터 (1544-1900)
반품/교환가능 기간 변심반품의 경우 수령 후 7일 이내,
상품의 결함 및 계약내용과 다를 경우 문제점 발견 후 30일 이내
반품/교환비용 변심 혹은 구매착오로 인한 반품/교환은 반송료 고객 부담
반품/교환 불가 사유
  • 소비자의 책임 있는 사유로 상품 등이 손실 또는 훼손된 경우
    (단지 확인을 위한 포장 훼손은 제외)
  • 소비자의 사용, 포장 개봉에 의해 상품 등의 가치가 현저히 감소한 경우
    예) 화장품, 식품, 가전제품(악세서리 포함) 등
  • 복제가 가능한 상품 등의 포장을 훼손한 경우
    예) 음반/DVD/비디오, 소프트웨어, 만화책, 잡지, 영상 화보집
  • 소비자의 요청에 따라 개별적으로 주문 제작되는 상품의 경우 ((1)해외주문도서)
  • 디지털 컨텐츠인 eBook, 오디오북 등을 1회 이상 다운로드를 받았을 경우
  • 시간의 경과에 의해 재판매가 곤란한 정도로 가치가 현저히 감소한 경우
  • 전자상거래 등에서의 소비자보호에 관한 법률이 정하는 소비자 청약철회 제한 내용에
    해당되는 경우
(1) 해외주문도서 : 이용자의 요청에 의한 개인주문상품으로 단순변심 및 착오로 인한 취소/교환/반품 시 ‘해외주문 반품/취소 수수료’ 고객 부담 (해외주문 반품/취소 수수료 : ①양서-판매정가의 12%, ②일서-판매정가의 7%를 적용)
상품 품절 공급사(출판사) 재고 사정에 의해 품절/지연될 수 있으며, 품절 시 관련 사항에 대해서는
이메일과 문자로 안내드리겠습니다.
소비자 피해보상
환불지연에 따른 배상
  • 상품의 불량에 의한 교환, A/S, 환불, 품질보증 및 피해보상 등에 관한 사항은
    소비자분쟁해결 기준 (공정거래위원회 고시)에 준하여 처리됨
  • 대금 환불 및 환불지연에 따른 배상금 지급 조건, 절차 등은 전자상거래 등에서의
    소비자 보호에 관한 법률에 따라 처리함

이 책의 원서번역서

안내

이 분야의 베스트

  • 길벗알앤디
    27,900원
  • 길벗R&D
    17,100원
  • 윤종식
    25,200원
  • 윤인성
    16,200원
  • 길벗R&D
    32,400원
더보기+

이 분야의 신간

  • 윤종식
    25,200원
  • BC카드 빅데이터센터
    17,100원
  • NCS 정보처리기술사 연구회
    25,200원
  • 조현준
    40,500원
  • NCS 정보기술 연구회
    27,900원
더보기+

바로가기

  • 우측 확장형 배너 2
  • 우측 확장형 배너 2

최근 본 상품