DOM Canvas 확대

황제낙엽 2016.08.22 13:09 조회 수 : 136

sitelink1 http://blog.naver.com/shadowbug/220743517764 
sitelink2  
sitelink3  
sitelink4  
extra_vars5  
extra_vars6  

캔버스를 확대시킨다.

 

 context

 설명

 scale(xRate, yRate)

 (xRate, yRate) 만큼 확대시킨다.

 

javascript

(100, 100) (150, 150) 위치의 사각형을 2배로 확대 시키는 예제이다.

rotate 하나만 사용해서 사각형을 원하는대로 확대시킬 수 없으며 

원점을 사각형의 중점으로 이동 시킨후 확대를 시켜야 생각한대로 확대되게 된다.

 

아래의 순서대로 차근차근 진행하면 올바르게 동작한다.

1. 2d의 평면상태 세팅 ( setTransform 매서드 )

2. 사각형의 중심부를 원점으로 세팅 ( translate )

3. 원하는 값으로 확대 ( scale )

4. 사각형의 중심부가 원점인 것을 인지하고 사각형을 그린다. ( fillRect )

 

이 패턴은  확대 뿐만 아니라 여러 예에서도 많이 사용되는 패턴이므로, 잘 숙달 할 필요가 있다.

  1.  

  2. function load(target) {

  3.     // 실제로 그려지는 위치의 캔버스 생성

  4.     var canvas = document.getElementById("draw");

  5.     var ctx = canvas.getContext("2d");

  6.  

  7.     // 입력값

  8.     var x = 100;

  9.     var y = 100;

  10.     var cx = 300;

  11.     var cy = 300;

  12.     var rate = 2;

  13.  

  14.     var width = cx - x;

  15.     var height = cy - y;

  16.     ctx.fillStyle = "red";

  17.  

  18.     // 2d 평면 상태 세팅

  19.     ctx.setTransform(1, 0, 0, 1, 0, 0);

  20.     // 사각형 안으로 원점 이동

  21.     ctx.translate(x + .5 * width, y + .5 * height);

  22.     // 확대

  23.     ctx.scale(rate, rate);

  24.     // 원점이 사각형의 중심임을 인지하고 그림 그리기

  25.     ctx.fillRect(-.5 * width, -.5 * height, width, height);

  26. }

결과

 

스크린샷_2016-06-22_오후_11.50.23.png

 

번호 제목 글쓴이 날짜 조회 수
88 HTML5 강좌 12강 - HTML5 태그 - canvas 채우기 스타일,그라데이션 file 황제낙엽 2016.12.03 212
87 HTML5 강좌 11강 - HTML5 태그 - canvas 베지에곡선, 선 스타일 file 황제낙엽 2016.12.03 166
86 HTML5 강좌 10강 - HTML5 태그 - canvas 원그리기 file 황제낙엽 2016.12.03 202
85 HTML5 강좌 9강 - HTML5 태그 - canvas 다각형 file 황제낙엽 2016.12.03 127
84 HTML5 강좌 8강 - HTML5 태그 - canvas 선그리기 file 황제낙엽 2016.12.03 136
83 HTML5 강좌 7강 - HTML5 태그 - canvas 사각형 file 황제낙엽 2016.12.03 118
82 HTML5 강좌 6강 - HTML5 태그 - canvas #1 file 황제낙엽 2016.12.03 205
81 HTML5 강좌 5강 - HTML5 태그 - prograss,download file 황제낙엽 2016.12.03 130
80 HTML5 강좌 4강 - HTML5 태그 - mark,time,meter file 황제낙엽 2016.12.03 141
79 HTML5 강좌 3강 - HTML5 레이아웃 잡아보기 file 황제낙엽 2016.12.03 139
78 HTML5 강좌 2강 - HTML5 시맨틱웹을 위한 구성요소 file 황제낙엽 2016.12.03 346
77 HTML5 강좌 1강 - HTML5 개념 및 기본구조 file 황제낙엽 2016.12.03 131
76 HTTP 오류 코드의 종류 황제낙엽 2016.12.01 138
75 Multiple Canvas Layer 예제 file 황제낙엽 2016.08.23 128
74 Canvas 개요 황제낙엽 2016.08.22 177
» Canvas 확대 file 황제낙엽 2016.08.22 136
72 Canvas setTransform 함수 황제낙엽 2016.08.22 148
71 Canvas 회전 file 황제낙엽 2016.08.22 152
70 Canvas 영역 선택 file 황제낙엽 2016.08.22 141
69 Canvas CanvasRenderingContext2D Context 속성 황제낙엽 2016.08.22 91