찾다
웹 프론트엔드H5 튜토리얼HTML5 CANVAS:绘制路径

1.jpg

  一条HTML5 canvas路径是通过绘制指令来连接一系列的点,由这一系列的点构成直线或曲线。路径可以用于在HTML5 canvas上绘制各种类型的图形:直线、圆形、多边形等等。路径的绘制是canvas的核心,必须很好的理解和掌握。

  开始和关闭一条路径

  要开始和关闭一条路径可以使用2D上下文的beginPath()和closePath()函数。例如下面的例子:
  1. var canvas  = document.getElementById("ex1");
  2. var context = canvas.getContext("2d");

  3. context.beginPath();

  4. //... 绘制路径

  5. context.closePath();      
复制代码

  moveTo()函数

  当你在canvas中绘制一条路径的时候,你可以想象自己正在使用一支“虚拟笔”。这支虚拟笔总是位于某个位置,你可以使用2D上下文的moveTo(x, y)函数来移动这支虚拟笔。例如下面的代码:
  1. context.moveTo(10,10);         
复制代码

  这个例子将“虚拟笔”移动到(10,10)这个坐标点上。

  lineTo()函数

  lineTo函数用于从虚拟笔的当前位置绘制一条直线到lineTo()函数中指定的点。下面是一个例子:
  1. context.beginPath();

  2. context.moveTo(10,10);
  3. context.lineTo(50,50);

  4. context.closePath();   
复制代码

  这个例子中首先移动虚拟笔到(10,10)坐标点位置,然后从这个点绘制一条直线到(50,50)坐标点。

  lineTo()函数还会将虚拟笔移动到执行的结束点位置。上面的例子中是移动到(50,50)的位置。

  stroke()函数 + fill()函数

  在你没有通知2D上下文绘制路径之前,实际是不会在画布上绘制任何东西的。你可以通过stroke()或fill()函数来通知2D上下文。

  stroke()函数用于路径操作指定的图形的外轮廓。

  fill()函数用于填充有路径操作指定的图形。

  下面的例子展示了stroke()或fill()函数的用法。
  1. context.beginPath();
  2. context.moveTo(10,10);
  3. context.lineTo(60,50);
  4. context.lineTo(110,50);
  5. context.lineTo(10,10);
  6. context.stroke();
  7. context.closePath();

  8. context.beginPath();
  9. context.moveTo(100,10);
  10. context.lineTo(150,50);
  11. context.lineTo(200,50);
  12. context.lineTo(100,10);
  13. context.fill();
  14. context.closePath();   
复制代码

  上面代码的返回结果如下:

2.jpg

  线条的宽度

  你可以使用2D上下文的lineWidth属性来设置绘制线条的宽度。下面是一个例子:
  1. context.lineWidth = 10;            
复制代码

  上面的例子设置绘制线条的宽度为10像素。

  下面的例子绘制3条直线,它们的宽度分别为1,5和10。

3.jpg

  当你绘制的线条宽度大于1的时候,扩展的线条宽度将平均分配在线条中心线的两侧。距离来说,如果你从(10,10)这个点绘制一条直线到(100,10)这个点,线条的宽度为10,那么,实际上是从(10,5)这个点开始绘制,然后扩展到(10,15)这个点,在水平绘制到(100,5)和(100,15)这两个点,就像是绘制一个矩形。

  线条的线条(LINE CAP)

  在使用路径来绘制线条的时候,你可以设置线条的线头样式。线头的样式通过2D上下文的lineCap属性来设置。它有三个可选值:

  •   butt
  •   round
  •   square

  butt样式的线头是扁平且和线正交的样式。

  round样式的线头是一个圆角的线头,圆的半径等于线条宽度的一半。

  square样式的线头会在线的末端绘制一个矩形。矩形的大小为:线条的宽度 X 线条的宽/2。

  下面是几个不同线头样式的线条的例子。所有的线条的宽度都是10。最总版的一组线条的lineCap的取值为butt,中间的一组线条的lineCap的取值为round,最右边的一组线条的lineCap的取值为square。

4.jpg

  lineCap的取值butt和square非常相似。有时难以区别。这里制作了几个小例子,从这些例子中你可以看出它们之间的微小差别。下面又三组线条,每一组左边(或上边)的线条的lineCap属性取值为butt,右边(或下边)的线条的lineCap属性取值为square。

5.jpg

  正如上面的结果所示,square线头的线条要比butt线头的线条要长。

  线条的连接

  2D上下文的lineJoin属性用于定义两条线条连接处的点如何绘制。两条线条连接处的点被称为“连接点”。lineJoin属性有下面的三种取值:

  •   miter
  •   bevel
  •   round

  下面是这三种取值的示例代码:
  1. context.lineJoin = "miter";
  2. context.lineJoin = "bevel";
  3. context.lineJoin = "round";         
复制代码

  miter的连接点是一个三角形的连接点。

  bevel的连接点是一个平头的连接点。

  round的连接点是一个圆角的连接点。

  下面分别是三种线条连接点的例子,从左到右的lineJoin属性分别是:miter,bevel和round。

6.jpg

  绘制曲线

  2D上下文的arc()函数可以用于绘制一条曲线。arc()函数有6个参数:

  •   x:圆弧的中心点的X坐标位置。
  •   y:圆弧的中心点的Y坐标位置。
  •   radius:圆弧的半径。
  •   startAngle:圆弧开始的角弧度。
  •   endAngle:圆弧结束的角弧度。
  •   anticlockwise:设置是以顺时针还是逆时针绘制圆弧,false为顺时针。

  下面是一段示例代码:
  1. context.lineWidth = 3;

  2. var x = 50;
  3. var y = 50;
  4. var radius = 25;
  5. var startAngle = (Math.PI / 180) * 45;
  6. var endAngle   = (Math.PI / 180) * 180;
  7. var anticlockwise = false;

  8. context.beginPath();
  9. context.arc(x, y, radius, startAngle, endAngle, anticlockwise);
  10. context.stroke();
  11. context.closePath();   
复制代码

  上面的代码绘制了一条弧线,它的中心点位于(50,50)坐标点,半径为25,从45度开始到180度结束。

  下面是上面代码的返回结果:

7.jpg

  上面的例子如果将anticlockwise设置为true,会得到下面的结果:

8.jpg

  如果你要花一个完整的圆,可以简单的设置startAngle为0,endAngle设置为2 * Math.PI,它相当于(Math.PI / 180) * 360。

  arcTo()函数

  2D上下文中有一个arcTo()函数,它用于从当前的点绘制一条曲线到参数指定的点,曲线的半径也由参数指定。它的语法为:arcTo(x1, y1, x2, y2, radius)。注意:参数中x1, y1, x2, y2指的是这个点的控制点。arcTo()函数可以使用lineTo()和arc函数来模仿。

  quadraticCurveTo()函数

  quadraticCurveTo()函数用于绘制一条二次贝兹曲线。这条曲线由一个控制点来控制,它的语法为:quadraticCurveTo(cp1x, cp1y, x, y)。下面是一个示例代码:
  1. context.lineWidth = 3;

  2. var fromX = 50;
  3. var fromY = 50;
  4. var toX   = 100;
  5. var toY   = 50;
  6. var cpX   = 75;
  7. var cpY   = 100;

  8. context.beginPath();
  9. context.moveTo(fromX, fromY);
  10. context.quadraticCurveTo(cpX, cpY, toX, toY);
  11. context.stroke();
  12. context.closePath();         
复制代码

  上面的代码绘制一条从(50,50)开始到(100,50)的二次贝兹曲线,这条曲线的控制点为(75,100)。得到的结果如下所示:

9.jpg

  仔细看,在曲线下方有一个小点,那是这条曲线的控制点。(这个点是专门绘制出来让大家看的)


  关于控制点,可以参考下面的图像:


10.jpg

  bezierCurveTo()函数

  bezierCurveTo()函数用于从一个点到另一个点绘制一条三次贝兹曲线。三次贝兹曲线有两个控制点,而二次贝兹曲线只有一个控制点。它的语法为:bezierCurveTo(cp1x, cp1y, cp2x, cp2y, x, y)。下面是一个例子:
  1. context.lineWidth = 3;

  2. var fromX = 50;
  3. var fromY = 50;
  4. var toX   = 300;
  5. var toY   = 50;
  6. var cp1X   = 100;
  7. var cp1Y   = 100;
  8. var cp2X   = 250;
  9. var cp2Y   = 100;

  10. context.beginPath();
  11. context.moveTo(fromX, fromY);
  12. context.bezierCurveTo(cp1X, cp1Y, cp2X, cp2Y, toX, toY);
  13. context.stroke();
  14. context.closePath();      
复制代码

  这段代码从(50,50)绘制一条三次贝兹曲线到(300,50),两个控制点分别为:(100,100)和(250,100)。得到的结果如下:

0.jpg

  曲线下方的两个小圆点是两个控制点,他们并不是曲线的一部分。

  下面是一个不同的例子,它的开始点和结束点于上面的例子相同,但是控制点和上面的例子不相同。
  1. context.lineWidth = 3;

  2. var fromX = 50;
  3. var fromY = 50;
  4. var toX   = 300;
  5. var toY   = 50;
  6. var cp1X   = 100;
  7. var cp1Y   = 10;
  8. var cp2X   = 250;
  9. var cp2Y   = 100;

  10. context.beginPath();
  11. context.moveTo(fromX, fromY);
  12. context.bezierCurveTo(cp1X, cp1Y, cp2X, cp2Y, toX, toY);
  13. context.stroke();
  14. context.closePath();      
复制代码

  上面的代码得到的结果如下:

11.jpg

  文章的最后,我们引用MDN上的一个例子,它用Canvas路径绘制出“吃豆人”游戏的一个小场景:

12.jpg

  实现的代码如下:
  1. function draw() {
  2.   var canvas = document.getElementById('canvas');
  3.   if (canvas.getContext){
  4.     var ctx = canvas.getContext('2d');

  5.     roundedRect(ctx,12,12,150,150,15);
  6.     roundedRect(ctx,19,19,150,150,9);
  7.     roundedRect(ctx,53,53,49,33,10);
  8.     roundedRect(ctx,53,119,49,16,6);
  9.     roundedRect(ctx,135,53,49,33,10);
  10.     roundedRect(ctx,135,119,25,49,10);

  11.     ctx.beginPath();
  12.     ctx.arc(37,37,13,Math.PI/7,-Math.PI/7,false);
  13.     ctx.lineTo(31,37);
  14.     ctx.fill();

  15.     for(var i=0;i
  16.       ctx.fillRect(51+i*16,35,4,4);
  17.     }

  18.     for(i=0;i
  19.       ctx.fillRect(115,51+i*16,4,4);
  20.     }

  21.     for(i=0;i
  22.       ctx.fillRect(51+i*16,99,4,4);
  23.     }

  24.     ctx.beginPath();
  25.     ctx.moveTo(83,116);
  26.     ctx.lineTo(83,102);
  27.     ctx.bezierCurveTo(83,94,89,88,97,88);
  28.     ctx.bezierCurveTo(105,88,111,94,111,102);
  29.     ctx.lineTo(111,116);
  30.     ctx.lineTo(106.333,111.333);
  31.     ctx.lineTo(101.666,116);
  32.     ctx.lineTo(97,111.333);
  33.     ctx.lineTo(92.333,116);
  34.     ctx.lineTo(87.666,111.333);
  35.     ctx.lineTo(83,116);
  36.     ctx.fill();

  37.     ctx.fillStyle = "white";
  38.     ctx.beginPath();
  39.     ctx.moveTo(91,96);
  40.     ctx.bezierCurveTo(88,96,87,99,87,101);
  41.     ctx.bezierCurveTo(87,103,88,106,91,106);
  42.     ctx.bezierCurveTo(94,106,95,103,95,101);
  43.     ctx.bezierCurveTo(95,99,94,96,91,96);
  44.     ctx.moveTo(103,96);
  45.     ctx.bezierCurveTo(100,96,99,99,99,101);
  46.     ctx.bezierCurveTo(99,103,100,106,103,106);
  47.     ctx.bezierCurveTo(106,106,107,103,107,101);
  48.     ctx.bezierCurveTo(107,99,106,96,103,96);
  49.     ctx.fill();

  50.     ctx.fillStyle = "black";
  51.     ctx.beginPath();
  52.     ctx.arc(101,102,2,0,Math.PI*2,true);
  53.     ctx.fill();

  54.     ctx.beginPath();
  55.     ctx.arc(89,102,2,0,Math.PI*2,true);
  56.     ctx.fill();
  57.   }
  58. }

  59. // A utility function to draw a rectangle with rounded corners.

  60. function roundedRect(ctx,x,y,width,height,radius){
  61.   ctx.beginPath();
  62.   ctx.moveTo(x,y+radius);
  63.   ctx.lineTo(x,y+height-radius);
  64.   ctx.quadraticCurveTo(x,y+height,x+radius,y+height);
  65.   ctx.lineTo(x+width-radius,y+height);
  66.   ctx.quadraticCurveTo(x+width,y+height,x+width,y+height-radius);
  67.   ctx.lineTo(x+width,y+radius);
  68.   ctx.quadraticCurveTo(x+width,y,x+width-radius,y);
  69.   ctx.lineTo(x+radius,y);
  70.   ctx.quadraticCurveTo(x,y,x,y+radius);
  71.   ctx.stroke();
  72. }               
复制代码

  本文版权属于jQuery之家,转载请注明出处:http://www.htmleaf.com/ziliaoku/ ... g/201507122217.html


성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
H5는 무엇을 언급합니까? 맥락 탐색H5는 무엇을 언급합니까? 맥락 탐색Apr 12, 2025 am 12:03 AM

h5referstohtml5, apivotaltechnologyinwebdevelopment.1) html5introducesnewelements 및 dynamicwebapplications.2) itsupp ortsmultimediawithoutplugins, enovannangeserexperienceacrossdevices.3) SemanticLementsImproveContentsTructUreAndSeo.4) H5'Srespo

H5 : 도구, 프레임 워크 및 모범 사례H5 : 도구, 프레임 워크 및 모범 사례Apr 11, 2025 am 12:11 AM

H5 개발에서 마스터 해야하는 도구 및 프레임 워크에는 vue.js, React 및 Webpack이 포함됩니다. 1.vue.js는 사용자 인터페이스를 구축하고 구성 요소 개발을 지원하는 데 적합합니다. 2. 복잡한 응용 프로그램에 적합한 가상 DOM을 통해 페이지 렌더링을 최적화합니다. 3. Webpack은 모듈 포장에 사용되며 리소스로드를 최적화합니다.

HTML5의 유산 : 현재 H5 이해HTML5의 유산 : 현재 H5 이해Apr 10, 2025 am 09:28 AM

html5hassignificallytransformedwebdevelopmentbyintranticalticlementements, 향상 Multimediasupport 및 Improvingperformance.1) itmadewebsitessmoreaccessibleadseo 친환경적 인 요소, 및 .2) Html5intagnatee

H5 코드 : 접근성 및 시맨틱 HTMLH5 코드 : 접근성 및 시맨틱 HTMLApr 09, 2025 am 12:05 AM

H5는 시맨틱 요소 및 ARIA 속성을 통해 웹 페이지 접근성 및 SEO 효과를 향상시킵니다. 1. 컨텐츠 구조를 구성하고 SEO를 개선하기 위해 사용합니다. 2. Aria-Label과 같은 ARIA 속성은 접근성을 향상시키고 보조 기술 사용자는 웹 페이지를 원활하게 사용할 수 있습니다.

H5는 html5와 동일합니까?H5는 html5와 동일합니까?Apr 08, 2025 am 12:16 AM

"H5"와 "HTML5"는 대부분의 경우 동일하지만 특정 시나리오에서는 다른 의미를 가질 수 있습니다. "HTML5"는 새로운 태그와 API를 포함하는 W3C 정의 표준입니다. "H5"는 일반적으로 HTML5의 약어이지만 모바일 개발에서는 HTML5를 기반으로 한 프레임 워크를 참조 할 수 있습니다. 이러한 차이를 이해하면 프로젝트 에서이 용어를 정확하게 사용하는 데 도움이됩니다.

H5의 기능은 무엇입니까?H5의 기능은 무엇입니까?Apr 07, 2025 am 12:10 AM

H5 또는 HTML5는 HTML의 다섯 번째 버전입니다. 개발자에게 더 강력한 도구 세트를 제공하여 복잡한 웹 애플리케이션을보다 쉽게 ​​만들 수 있습니다. H5의 핵심 기능에는 다음이 포함됩니다. 1) 웹 페이지에 그래픽 및 애니메이션을 그리는 요소; 2) 웹 페이지 구조를 SEO 최적화에 명확하고 도움이되는 시맨틱 태그 등; 3) GeolocationApi 지원 위치 기반 서비스와 같은 새로운 API; 4) 호환성 테스트 및 폴리 필 라이브러리를 통해 크로스 브라우저 호환성을 보장해야합니다.

H5 링크를 수행하는 방법H5 링크를 수행하는 방법Apr 06, 2025 pm 12:39 PM

H5 링크를 만드는 방법? 링크 대상 결정 : H5 페이지 또는 응용 프로그램의 URL을 가져옵니다. HTML 앵커 작성 : & lt; a & gt; 태그 앵커를 만들고 링크 대상 URL을 지정합니다. 링크 속성 설정 (선택 사항) : 필요에 따라 대상, 제목 및 on 클릭 속성을 설정하십시오. 웹 페이지에 추가 : 링크가 나타나려는 웹 페이지에 HTML 앵커 코드를 추가하십시오.

H5 호환성 문제를 해결하는 방법H5 호환성 문제를 해결하는 방법Apr 06, 2025 pm 12:36 PM

H5 호환성 문제에 대한 솔루션에는 다음이 포함됩니다. 웹 페이지가 화면 크기에 따라 레이아웃을 조정할 수있는 반응 형 디자인을 사용합니다. 릴리스 전에 호환성을 테스트하기 위해 브라우저 크로스 브라우저 테스트 도구를 사용하십시오. PolyFill을 사용하여 이전 브라우저의 새로운 API를 지원합니다. 웹 표준을 따르고 효과적인 코드 및 모범 사례를 사용하십시오. CSS 프리 프로세서를 사용하여 CSS 코드를 단순화하고 가독성을 향상시킵니다. 이미지를 최적화하고 웹 페이지 크기를 줄이며로드 속도를 높이십시오. HTTPS를 통해 웹 사이트의 보안을 보장하십시오.

See all articles

핫 AI 도구

Undresser.AI Undress

Undresser.AI Undress

사실적인 누드 사진을 만들기 위한 AI 기반 앱

AI Clothes Remover

AI Clothes Remover

사진에서 옷을 제거하는 온라인 AI 도구입니다.

Undress AI Tool

Undress AI Tool

무료로 이미지를 벗다

Clothoff.io

Clothoff.io

AI 옷 제거제

AI Hentai Generator

AI Hentai Generator

AI Hentai를 무료로 생성하십시오.

인기 기사

R.E.P.O. 에너지 결정과 그들이하는 일 (노란색 크리스탈)
3 몇 주 전By尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. 최고의 그래픽 설정
3 몇 주 전By尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. 아무도들을 수없는 경우 오디오를 수정하는 방법
3 몇 주 전By尊渡假赌尊渡假赌尊渡假赌
WWE 2K25 : Myrise에서 모든 것을 잠금 해제하는 방법
3 몇 주 전By尊渡假赌尊渡假赌尊渡假赌

뜨거운 도구

에디트플러스 중국어 크랙 버전

에디트플러스 중국어 크랙 버전

작은 크기, 구문 강조, 코드 프롬프트 기능을 지원하지 않음

메모장++7.3.1

메모장++7.3.1

사용하기 쉬운 무료 코드 편집기

SecList

SecList

SecLists는 최고의 보안 테스터의 동반자입니다. 보안 평가 시 자주 사용되는 다양한 유형의 목록을 한 곳에 모아 놓은 것입니다. SecLists는 보안 테스터에게 필요할 수 있는 모든 목록을 편리하게 제공하여 보안 테스트를 더욱 효율적이고 생산적으로 만드는 데 도움이 됩니다. 목록 유형에는 사용자 이름, 비밀번호, URL, 퍼징 페이로드, 민감한 데이터 패턴, 웹 셸 등이 포함됩니다. 테스터는 이 저장소를 새로운 테스트 시스템으로 간단히 가져올 수 있으며 필요한 모든 유형의 목록에 액세스할 수 있습니다.

MinGW - Windows용 미니멀리스트 GNU

MinGW - Windows용 미니멀리스트 GNU

이 프로젝트는 osdn.net/projects/mingw로 마이그레이션되는 중입니다. 계속해서 그곳에서 우리를 팔로우할 수 있습니다. MinGW: GCC(GNU Compiler Collection)의 기본 Windows 포트로, 기본 Windows 애플리케이션을 구축하기 위한 무료 배포 가능 가져오기 라이브러리 및 헤더 파일로 C99 기능을 지원하는 MSVC 런타임에 대한 확장이 포함되어 있습니다. 모든 MinGW 소프트웨어는 64비트 Windows 플랫폼에서 실행될 수 있습니다.

ZendStudio 13.5.1 맥

ZendStudio 13.5.1 맥

강력한 PHP 통합 개발 환경