확장메뉴
주요메뉴


닫기
사이즈 비교
소득공제
HTML5 캔버스 완벽 가이드

HTML5 캔버스 완벽 가이드

: 그래픽, 애니메이션, 게임 개발을 위한 캔버스 API의 모든 것

리뷰 총점10.0 리뷰 1건 | 판매지수 72
베스트
웹사이트 top100 29주
정가
40,000
판매가
36,000 (10% 할인)
배송안내
서울특별시 영등포구 은행로 11(여의도동, 일신빌딩)
지역변경
  • 배송비 : 무료 ?
eBook이 출간되면 알려드립니다. eBook 출간 알림 신청
분철서비스 시작 시 알려드립니다. 분철서비스 알림신청
  •  해외배송 가능
  •  최저가 보상
  •  문화비소득공제 신청가능

품목정보

품목정보
발행일 2012년 12월 13일
쪽수, 무게, 크기 716쪽 | 1530g | 188*240*40mm
ISBN13 9788998139070
ISBN10 8998139073

책소개 책소개 보이기/감추기

목차 목차 보이기/감추기

책 속으로 책속으로 보이기/감추기

이 책은 크게 두 부분으로 구분된다. 처음 네 개의 장으로 책의 절반을 차지하고 있는 책의 전반부에서는 도형 및 텍스트를 캔버스에 그리는 방법과 이미지를 조작하고 그리는 방법을 소개하는 캔버스 API를 다룬다. 그리고 후반부인 나머지 일곱 개의 장에서는 API를 사용해 애니메이션과 움직이는 스프라이트를 구현하고 시뮬레이션을 생성, 충돌 감지, 비디오 게임을 개발하는 방법을 소개한다. 참고로, 이 책의 마지막 장인 11장에서는 프로그레스 바, 슬라이더, 이미지 패너 등과 같은 사용자 정의 컨트롤을 구현하는 방법과 캔버스 기반 모바일 애플리케이션을 생성하는 방법도 소개한다.

1장 "캔버스 구성(Essentials)"에서는 [canvas] 요소를 소개하고 웹 애플리케이션에서 [canvas] 요소를 사용하는 방법과 브라우저, 콘솔, 디버거, 프로파일러, 타임라인 등을 다루는 HTML5 개발에 대해 간단히 소개한다. 또한, 캔버스에 그리기, 캔버스 파라미터 및 드로잉 표면을 저장하고 복원하기, 캔버스 출력하기, 오프스크린 캔버스 개론 등과 같은 캔버스의 필수 구성 요소를 구현하는 방법도 소개한다. 1장의 마지막 부분에서는 측정 단위로부터 방정식을 유도하는 방법과 벡터 계산, 삼각법, 기본 대수학을 다룬 수학 입문서도 간략하게 소개한다.

2장 "드로잉"에서는 이 책에서 내용이 가장 많은 장으로 선, 호, 곡선, 원, 직사각형, 임의 다각형을 캔버스에 그리는 방법과 색상, 그라디언트, 패턴 등을 사용해 도형 내부를 칠하는 방법을 소개하며 캔버스 API를 사용한 드로잉을 심도 있게 다룬다. 또한, 2장에서는 도형을 그릴 수 있게 임시 러버 밴드를 그리는 방법, 캔버스 내부에서 도형을 드래그하는 방법, 사용자가 편집할 수 있도록 캔버스에 다각형을 기록하는 간단한 보유 모드(retained mode) 그래픽 서브시스템을 구현하는 방법, 클리핑 영역을 사용해 캔버스 배경을 건드리지 않고 도형을 지우는 방법 등과 같이 단순한 드로잉 기법의 범위를 넘어 캔버스 API를 사용한 드로잉을 구현하는 방법을 소개한다.

3장 "텍스트"에서는 캔버스에서 텍스트를 그리고 조작하는 방법을 소개한다. 따라서 텍스트 내부를 칠하고 윤곽을 그리는 방법과 폰트 속성을 설정하고 캔버스에 텍스트를 위치시키는 방법 등을 살펴 본다. 또한, 3장에서는 텍스트 커서와 편집할 수 있는 단락과 함께 캔버스에서 텍스트 컨트롤을 구현하는 방법도 소개한다.

4장 "이미지 및 비디오"에서는 이미지, 이미지 조작, 비디오 프로세싱을 중점으로 소개하므로 캔버스에서 이미지를 확대하고 그리는 방법을 살펴보고 각 픽셀의 색상 구성 요소에 접근해 이미지를 조작하는 방법을 배운다. 또한, 클리핑 영역을 사용하는 방법과 이미지를 움직이는 방법을 살펴 보고 비디오 프로세싱을 소개한 4장의 마지막 절로 넘어가기 전에 보안과 성능에 대해 다룬다.

5장 "애니메이션"에서는 《스크립트 기반 애니메이션을 위한 타이밍 컨트롤(Timing control for script-based animations)》이란 제목의 W3C 명세서에서 정의한 requestAnimationFrame() 메서드를 사용해 애니메이션을 자연스럽게 재생할 수 있는 구현 방법을 소개 한다. 그리고 애니메이션의 프레임률을 계산하는 방법과 임시 프레임률로 애니메이션의 사용자 인터페이스를 업데이트하는 등과 같이 다른 활동에 대한 일정을 잡는 방법도 살펴본다. 또한, 5장에서는 애니메이션이 실행되는 동안 세 가지 다른 방법을 사용해 배경을 복원하는 방법을 소개하고 각 방법에 따라 성능에 미치는 영향을 살펴보겠다. 그뿐만 아니라 시간 기반 모션을 구현하는 방법, 애니메이션의 배경을 스크롤하는 방법, 시차를 사용해 3D처럼 보이게 하는 방법, 애니메이션이 실행되는 동안 사용자 제스처를 감지하고 처리하는 방법도 살펴볼 것이다. 마지막으로 애니메이션 모범 사례를 소개하기 전에 간단한 애니메이션 타이머를 구현하는 방법과 시한 애니메이션을 살펴볼 것이다.

6장 "스프라이트"에서는 자바스크립트에서 움직이는 오브젝트인 스프라이트를 구현하는 방법을 소개한다. 스프라이트는 시각적인 표현, 주로 이미지를 가지고 있으므로 캔버스에서 스프라이트를 이동시킬 수 있을 뿐만 아니라 일련의 이미지를 순환하여 스프라이트를 움직이게 만들 수도 있다. 따라서 스프라이트는 게임을 구성하는 기본 구성 요소라고 할 수 있다.

7장 "물리학"에서는 떨어지는 물체와 탄도 궤적을 모델링하는 방법부터 진자 운동에 이르기까지 애니메이션에서 물리학을 시뮬레이션하는 방법을 보여준다. 또한, 7장에서는 애니메이션에서 시간과 모션을 모두 왜곡해 단거리 주자가 달릴 때 발생하는 가속 효과(ease-in)나 자동차가 브레이크를 잡을 때 발생하는 감속 효과(ease-out) 등과 같이 실제 움직임을 시뮬레이션하는 방법도 살펴볼 것이다.

대부분 게임에서 충돌 감지를 핵심 기능으로 취급하므로 8장 "충돌 감지"에서는 스프라이트 사이에 발생하는 충돌을 감지하는 방법도 자세히 소개한다. 8장의 시작 부분에서는 구현하기 쉬울 뿐만 아니라 신뢰도가 높은 경계 박스와 원을 사용한 간단한 충돌 감지를 구현하는 방법을 소개한다.

하지만 간단한 충돌 감지를 사용하면 다양한 환경에 대처하는 능력이 부족해지므로 2D와 3D에서 임의 다각형 사이에 발생하는 충돌을 감지하는데 효과적인 방법 중 하나인 SAT(Sepatating Axis Theorem)를 소개하는데 8장의 대부분을 사용하고 있다. 그러나 SAT는 수학적 측면이 강하므로 더 쉬운 용어로 SAT를 소개할 수 있도록 많은 노력을 기울였다.

9장 "게임 개발"에서는 스프라이트를 그리는 작업과 하이 스코어를 관리하는 작업부터 시간 기반 모션과 멀티 트랙 사운드에 이르기까지 모든 기능을 제공할 뿐만 아니라 간단하면서 효과적인 게임 엔진에 대한 코드를 살펴보는 것으로 시작한다. 9장에서는 두 가지 게임을 소개한다. 첫 번째 게임은 간단한 Hello World 형태의 게임으로 게임 엔진을 사용하는 방법과 게임에 대한 시작 포인트를 알려준다. 또한, 첫 번째 게임으로 하이 스코어를 위한 사용자 인터페이스, 자산 관리, 헤드-업 디스플레이 등과 같이 대부분 게임에서 일반적으로 사용되는 기능을 구현하는 방법을 소개한다. 두 번째 게임은 강력한 핀볼게임으로 책 앞부분에서 소개한 내용을 사용해 구현하고 있으며 실제 게임에서처럼 복잡한 충돌 감지를 사용하고 있다.

많은 캔버스 기반 애플리케이션에서 사용자 정의 컨트롤을 필요로 하므로 10장 "사용자 정의 컨트롤"에서는 사용자 정의 컨트롤을 구현하는 방법을 소개한다. 10장에서는 일반적으로 사용자 정의 컨트롤을 구현하는 방법을 소개하고 모서리가 둥근 직사각형, 프로그레스 바, 슬라이더, 이미지 패너 등 네 가지 사용자 정의 컨트롤을 이용하는 방법을 보여준다.

마지막 장인 "모바일"에서는 캔버스 기반 모바일 애플리케이션을 구현하는데 중점을 두고 있으므로 애플리케이션을 모바일 장치에서 표시할 수 있도록 애플리케이션의 뷰 포트 크기를 제어하는 방법과 CSS3 미디어 쿼리를 사용해 화면 크기와 방향을 처리하는 방법을 살펴본다. 또한 캔버스 기반 애플리케이션을 데스크톱 전체 화면으로 실행하고 아이콘과 시작 스크린에 맞춤으로써 iOS5 전용 애플리케이션과 구별되지 않은 캔버스 기반 애플리케이션을 구현하는 방법도 소개한다. 그리고 11장의 마지막 부분에서는 텍스트 필드로 텍스트를 입력 받지 않는 iOS5 애플리케이션용 키보드를 구현하는 방법을 소개한다.
---「서문」 중에서

출판사 리뷰 출판사 리뷰 보이기/감추기

회원리뷰 (1건) 회원리뷰 이동

한줄평 (0건) 한줄평 이동

  등록된 한줄평이 없습니다!

첫번째 한줄평을 남겨주세요.

배송/반품/교환 안내

배송 안내
반품/교환 안내에 대한 내용입니다.
배송 구분 예스24 배송
  •  배송비 : 무료배송
포장 안내

안전하고 정확한 포장을 위해 CCTV를 설치하여 운영하고 있습니다.

고객님께 배송되는 모든 상품을 CCTV로 녹화하고 있으며, 철저한 모니터링을 통해 작업 과정에 문제가 없도록 최선을 다 하겠습니다.

목적 : 안전한 포장 관리
촬영범위 : 박스 포장 작업

  • 포장안내1
  • 포장안내2
  • 포장안내3
  • 포장안내4
반품/교환 안내

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

반품/교환 안내에 대한 내용입니다.
반품/교환 방법
  •  고객만족센터(1544-3800), 중고샵(1566-4295)
  •  판매자 배송 상품은 판매자와 반품/교환이 협의된 상품에 한해 가능합니다.
반품/교환 가능기간
  •  출고 완료 후 10일 이내의 주문 상품
  •  디지털 콘텐츠인 eBook의 경우 구매 후 7일 이내의 상품
  •  중고상품의 경우 출고 완료일로부터 6일 이내의 상품 (구매확정 전 상태)
  •  모바일 쿠폰의 경우 유효기간(발행 후 1년) 내 등록하지 않은 상품
반품/교환 비용
  •  고객의 단순변심 및 착오구매일 경우 상품 반송비용은 고객 부담임
  •  직수입양서/직수입일서중 일부는 변심 또는 착오로 취소시 해외주문취소수수료 20%를 부과할수 있음

    단, 아래의 주문/취소 조건인 경우, 취소 수수료 면제

    •  오늘 00시 ~ 06시 30분 주문을 오늘 오전 06시 30분 이전에 취소
    •  오늘 06시 30분 이후 주문을 익일 오전 06시 30분 이전에 취소
  •  직수입 음반/영상물/기프트 중 일부는 변심 또는 착오로 취소 시 해외주문취소수수료 30%를 부과할 수 있음

    단, 당일 00시~13시 사이의 주문은 취소 수수료 면제

  •  박스 포장은 택배 배송이 가능한 규격과 무게를 준수하며, 고객의 단순변심 및 착오구매일 경우 상품의 반송비용은 박스 당 부과됩니다.
반품/교환 불가사유
  •  소비자의 책임 있는 사유로 상품 등이 손실 또는 훼손된 경우
  •  소비자의 사용, 포장 개봉에 의해 상품 등의 가치가 현저히 감소한 경우 : 예) 화장품, 식품, 가전제품, 전자책 단말기 등
  •  복제가 가능한 상품 등의 포장을 훼손한 경우 : 예) CD/LP, DVD/Blu-ray, 소프트웨어, 만화책, 잡지, 영상 화보집
  •  소비자의 요청에 따라 개별적으로 주문 제작되는 상품의 경우
  •  디지털 컨텐츠인 eBook, 오디오북 등을 1회 이상 다운로드를 받았을 경우
  •  eBook 대여 상품은 대여 기간이 종료 되거나, 2회 이상 대여 했을 경우 취소 불가
  •  모바일 쿠폰 등록 후 취소/환불 불가
  •  중고상품이 구매확정(자동 구매확정은 출고완료일로부터 7일)된 경우
  •  LP상품의 재생 불량 원인이 기기의 사양 및 문제인 경우 (All-in-One 일체형 일부 보급형 오디오 모델 사용 등)
  •  시간의 경과에 의해 재판매가 곤란한 정도로 가치가 현저히 감소한 경우
  •  전자상거래 등에서의 소비자보호에 관한 법률이 정하는 소비자 청약철회 제한 내용에 해당되는 경우
소비자 피해보상
  •  상품의 불량에 의한 반품, 교환, A/S, 환불, 품질보증 및 피해보상 등에 관한 사항은 소비자분쟁해결기준(공정거래위원회 고시)에 준하여 처리됨
환불 지연에
따른 배상
  •  대금 환불 및 환불 지연에 따른 배상금 지급 조건, 절차 등은 전자상거래 등에서의 소비자 보호에 관한 법률에 따라 처리
  •  쿠폰은 결제 시 적용해 주세요.
1   36,000
뒤로 앞으로 맨위로 공유하기