>웹 프론트엔드 >H5 튜토리얼 >canvas_html5 튜토리얼 스킬 사용 시 주의할 점 요약

canvas_html5 튜토리얼 스킬 사용 시 주의할 점 요약

WBOY
WBOY원래의
2016-05-16 15:49:051391검색

1. 캔버스 중국어 튜토리얼 https://developer.mozilla.org/zh-CN/docs/Canvas_tutorial

2. 캔버스의 기본 너비와 높이는 300과 150입니다. 예외를 피하려면 다음을 수행하는 것이 가장 좋습니다. 디스플레이 속성을 사용하여 CSS를 사용하지 않고 너비와 높이를 추가합니다

3. 캔버스 태그 내부에 캔버스 태그를 지원하지 않는 브라우저에 대한 지침을 추가합니다

4. 브라우저는 다음 js 코드를 통해 캔버스를 지원합니다

코드 복사
코드는 다음과 같습니다

var canvas = document.getElementById('tutorial');
if (canvas.getContext){
var ctx = canvas.getContext('2d')
// 여기에 코드 그리기
} else {
// 캔버스가 지원되지 않는 코드는 여기
}

5. 캔버스는 하나의 기본 도형, 즉 직사각형 그리기만 지원하지만 다른 그래픽은 이를 통해 그릴 수 있습니다. 캔버스 경로

6. 사각형 그리기 4가지 함수가 있습니다: ect, fillRect, strokeRect 및clearRect

7. BeginPath를 추가하지 않으면 새 경로 레이어를 시작하는 데 사용됩니다. 원래 경로 레이어의 효과는 완전히 다릅니다. 첫 번째 코드는 두 개의 빨간색 선을 표시하고 두 번째 코드는 하나의 검은색 선과 하나의 빨간색 선을 표시합니다.

코드 복사
코드는 다음과 같습니다.

var ctx = document.getElementById('cvs').getContext('2d');
ctx.beginPath();
ctx.moveTo(100.5,20.5);
ctx.lineTo(200.5,20.5);
ctx.stroveTo(100.5) ,40.5);
ctx.lineTo(200.5,40.5)
ctx.StrokeStyle = '#f00';
ctx.Stroke()



코드 복사 코드는 다음과 같습니다.
var ctx = document.getElementById('cvs').getContext( '2d');
ctx.beginPath();
ctx .moveTo(100.5,20.5)
ctx.lineTo(200.5,20.5); ctx.beginPath();
ctx.moveTo(100.5,40.5);
ctx.lineTo(200.5,40.5)
ctx.StrokeStyle = '#f00'
ctx.Stroke();


8. 경로를 닫을 필요가 없으면 closePath를 사용할 필요가 없습니다. fill을 사용하면 더 이상 closePath를 사용할 필요가 없습니다. 9. 인내심이 충분하다면 Searle 곡선을 사용하여 모든 그래픽을 그릴 수 있습니다

10. Firefox에서는 2차 곡선에 버그가 있으므로 3차 곡선을 사용할 수 있습니다. 2차 곡선 대신 곡선

11. 이미지(예: PNG, GIF, JPEG 등)를 캔버스에 도입할 수 있으며, 다른 캔버스 요소도 이미지 소스로 사용할 수 있습니다

12. 다음은 기본 캔버스 이미지 그리기 코드입니다. 여기서 image는 이미지 또는 캔버스 개체이고, x와 y는 대상 캔버스의 시작 좌표입니다.

drawImage(image, x, y)
다음 코드는 이미지 크기 조정을 나타내고, 너비와 높이는 확대된 크기를 나타냅니다.
drawImage(image, x , y, width, height)
다음 코드는 이미지 자르기를 나타냅니다. 첫 번째 매개변수는 동일합니다. 다른 것과 마찬가지로 둘 다 이미지나 다른 캔버스에 대한 참조입니다. 나머지 8개의 매개변수는 각각 그림에서 자르기 시작 x 좌표, 그림에서 자르기 시작 y 좌표, 자르기 영역의 너비, 자르기 영역의 높이, 그려진 위치의 x 좌표, y를 나타냅니다. 그려지는 위치의 좌표와 그려지는 그래픽의 너비는 그려지는 그래픽의 크기와 다를 수 있습니다. 그려진 그림

drawImage(image, sx, sy, sWidth, sHeight, dx , dy, dWidth, dHeight)
13. 스트로크 스타일은 그래픽 윤곽선의 색상을 설정하는 데 사용되며, 채우기 스타일은 사용됩니다. 채우기 색상을 설정합니다. color는 CSS 색상 값을 나타내는 문자열, 그라데이션 객체 또는 패턴 객체일 수 있습니다. 기본적으로 선 및 채우기 색상은 검은색입니다(CSS 색상 값 #000000).

14. 이미지 투명도는 globalAlpha = 투명도 값 또는 rgba 색상 값으로 표현할 수 있습니다

15. lineWidth 속성은 1px 선 너비를 해결하기 위해 설정합니다. 버그 문제 0.5 사용 해결 방법

16. lineCap 속성의 가장 왼쪽 줄은 기본 버튼을 사용합니다. 안내선과 같은 높이인지 확인하세요. 가운데는 선 너비의 절반 반경이 끝점에 추가된 반원이 있는 둥근 효과입니다. 오른쪽은 너비가 같고 선 너비의 절반이 끝점에 추가된 사각형의 효과입니다.

17. lineJoin 속성 여기서도 예로 세 개의 폴리라인을 사용하고 서로 다른 lineJoin을 설정했습니다. 각각의 가치. 맨 위는 둥근 효과이고 모서리는 둥글며 원의 반경은 선 너비와 같습니다. 가운데 선과 아래쪽 선은 각각 경사와 마이터의 효과입니다. 값이 마이터인 경우 선분은 한 지점에서 교차할 때까지 연결 외부로 확장됩니다.

18 아래에 소개되는 miterLimit 속성에 의해 확장 효과가 제한됩니다. 캔버스 상태를 저장하고 복원합니다. 모두 매개변수가 없습니다. Canvas의 상태는 현재 화면에 적용된 모든 스타일과 변환의 스냅샷입니다. 캔버스 상태는 스택에 저장됩니다. save 메서드가 호출될 때마다 현재 상태가 스택에 푸시되어 저장됩니다. 복원 메서드가 호출될 때마다 마지막으로 저장된 상태가 힙에서 팝되고 모든 설정이 복원됩니다.

19. 변환(1, 0, 0, 1, 0, 0) 매개변수는 각각 수평 스케일링, 수평 회전(시계 방향), 수직 회전(반시계 방향), 수직 스케일링, 수평 방향 오프셋, 수직 오프셋을 나타냅니다.
 setTransform(1, 0, 0, 1, 0, 0)은 이전 변환 행렬을 재설정한 다음 새 행렬을 구성하는 것을 의미합니다. 매개 변수 함수는 위와 동일합니다.
rotate(angle), (반경) 는 1라디안, 2πr/r=라디안, 즉 360=2π, 즉 1=π/180)

20. 애니메이션은 실제로 드로잉 보드(clearRect())를 계속해서 지우는 것입니다. ) 그런 다음 다시 그립니다.
성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.