> 웹 프론트엔드 > HTML 튜토리얼 > Canvas入门(1):绘制矩形、圆、直线、曲线等基本图形_html/css_WEB-ITnose

Canvas入门(1):绘制矩形、圆、直线、曲线等基本图形_html/css_WEB-ITnose

WBOY
풀어 주다: 2016-06-24 11:56:30
원래의
1110명이 탐색했습니다.

来源:http://www.ido321.com/968.html

一、Canvas的基础知识

Canvas是HTML 5中新增的元素,专门用于绘制图形。canvas元素就相当于一块“画布”,一块无色的透明区域,需要利用JavaScript编写在其中进行绘画的脚本。

在页面放置canvas元素很简单,利用标签,同时指定几个基本的属性:id,width和height。接下来通过几个小案例,跟我入门canvas吧~~~^_^~~~

二、Canvas小案例(测试结果来自Google最新版本)

1、绘制矩形

canvas.html:

   1: <!DOCTYPE >
로그인 후 복사
   2: <html>
로그인 후 복사
   3: <head>
로그인 후 복사
   4: <meta charset="utf-8">
로그인 후 복사
   5: <title>canvas元素学习</title>
로그인 후 복사
   6: <script type="text/javascript" src="canvas.js">
로그인 후 복사
   7: </script>
로그인 후 복사
   8: </head>
로그인 후 복사
   9: <body>
로그인 후 복사
  10:     <h3>canvas元素学习</h3>
로그인 후 복사
  11:     <canvas id="canvas" width="400" height="300"></canvas>
로그인 후 복사
  12: </body>
로그인 후 복사
  13: </html>
로그인 후 복사

canvas.js:

   1: window.onload=function()
로그인 후 복사
   2: {
로그인 후 복사
   3:     // 获取canvas 的ID
로그인 후 복사
   4:     var canvas = document.getElementById('canvas');
로그인 후 복사
   5:     if (canvas == null)
로그인 후 복사
   6:     {
로그인 후 복사
   7:         return false;
로그인 후 복사
   8:     }
로그인 후 복사
   9:     // 获取上下文
로그인 후 복사
  10:     var context = canvas.getContext('2d');
로그인 후 복사
  11:     // 设置填充的样式
로그인 후 복사
  12:     context.fillStyle = "#eeeeff";
로그인 후 복사

13: // 绘制矩形,以fillStyle填充,fillRect(strokeRect)前两个参数是矩形左上角位置,后两个参数分别是宽和高

//默认原点是canvas的左上角

  14:     context.fillRect(0,0,400,300);
로그인 후 복사
  15:     context.fillStyle = 'red';
로그인 후 복사
  16:     // 设置边框的样式
로그인 후 복사
  17:     context.strokeStyle = 'blue';
로그인 후 복사
  18:     // 设置边框大小
로그인 후 복사
  19:     context.lineWidth = 2;
로그인 후 복사
  20:     context.fillRect(50,50,100,100);
로그인 후 복사
  21:     // 绘制矩形边框
로그인 후 복사
  22:     context.strokeRect(50,50,100,100);
로그인 후 복사
  23: }
로그인 후 복사

效果:

2、绘制圆形:使用路径绘制

   1: // 获取canvas 的ID
로그인 후 복사
로그인 후 복사
로그인 후 복사
로그인 후 복사
   2:     var canvas = document.getElementById('canvas');
로그인 후 복사
로그인 후 복사
로그인 후 복사
로그인 후 복사
   3:     if (canvas == null)
로그인 후 복사
로그인 후 복사
로그인 후 복사
로그인 후 복사
   4:     {
로그인 후 복사
로그인 후 복사
로그인 후 복사
로그인 후 복사
   5:         return false;
로그인 후 복사
로그인 후 복사
로그인 후 복사
로그인 후 복사
   6:     }
로그인 후 복사
로그인 후 복사
로그인 후 복사
로그인 후 복사
   7:     // 获取上下文
로그인 후 복사
로그인 후 복사
로그인 후 복사
로그인 후 복사
   8:     var context = canvas.getContext('2d');
로그인 후 복사
로그인 후 복사
로그인 후 복사
로그인 후 복사
   9:     // 设置填充的样式
로그인 후 복사
로그인 후 복사
로그인 후 복사
로그인 후 복사
  10:     context.fillStyle = "#eeeeff";
로그인 후 복사
로그인 후 복사
로그인 후 복사
로그인 후 복사
  11:     // 绘制矩形,以fillStyle填充
로그인 후 복사
로그인 후 복사
로그인 후 복사
로그인 후 복사
  12:     context.fillRect(0,0,400,300);
로그인 후 복사
로그인 후 복사
로그인 후 복사
로그인 후 복사
  13:     for(var i = 0; i<9; i++)
로그인 후 복사
  14:     {
로그인 후 복사
  15:         // 创建路径
로그인 후 복사
  16:         context.beginPath();
로그인 후 복사
  17:         // 绘制圆形路径
로그인 후 복사
  18:         context.arc(i*25, i*25, i*10, 0, Math.PI * 2, true);
로그인 후 복사
  19:         // 关闭路径,如果不关闭,则图像会重叠
로그인 후 복사
  20:         context.closePath();
로그인 후 복사
  21:         context.fillStyle = 'rgba(255,0,0,0.25)';
로그인 후 복사
  22:         // 以fillStyle填充
로그인 후 복사
  23:         context.fill();
로그인 후 복사
  24:     }
로그인 후 복사

arc()绘制圆弧,其参数如下

arc(x,y,radius,startAngle,endAngle,anticlockwise):x,y 是圆弧的圆心位置,radius是半径,startAngle和endAngle是起始和结束的角度,单位是弧度(度数必须转为弧 度),anticlockwise是一个布尔值,true表示顺时针绘制图像,false表示逆时针绘制。起始角度是0,结束角度是360(PI*2)就 可以绘制圆形。

效果:

3、绘制直线

绘制直线用到moveTo()和lineTo()两个方法

   1: // 获取canvas 的ID
로그인 후 복사
로그인 후 복사
로그인 후 복사
로그인 후 복사
   2:     var canvas = document.getElementById('canvas');
로그인 후 복사
로그인 후 복사
로그인 후 복사
로그인 후 복사
   3:     if (canvas == null)
로그인 후 복사
로그인 후 복사
로그인 후 복사
로그인 후 복사
   4:     {
로그인 후 복사
로그인 후 복사
로그인 후 복사
로그인 후 복사
   5:         return false;
로그인 후 복사
로그인 후 복사
로그인 후 복사
로그인 후 복사
   6:     }
로그인 후 복사
로그인 후 복사
로그인 후 복사
로그인 후 복사
   7:     // 获取上下文
로그인 후 복사
로그인 후 복사
로그인 후 복사
로그인 후 복사
   8:     var context = canvas.getContext('2d');
로그인 후 복사
로그인 후 복사
로그인 후 복사
로그인 후 복사
   9:     // 设置填充的样式
로그인 후 복사
로그인 후 복사
로그인 후 복사
로그인 후 복사
  10:     context.fillStyle = "#eeeeff";
로그인 후 복사
로그인 후 복사
로그인 후 복사
로그인 후 복사
  11:     // 绘制矩形,以fillStyle填充
로그인 후 복사
로그인 후 복사
로그인 후 복사
로그인 후 복사
  12:     context.fillRect(0,0,400,300);
로그인 후 복사
로그인 후 복사
로그인 후 복사
로그인 후 복사

13: context.beginPath();

//参数线的起点坐标

14: context.moveTo(50,50);

//参数线的终点坐标

  15:     context.lineTo(100,100);
로그인 후 복사

16: context.closePath();

//关闭路径之后绘制图形

  17:     context.strokeStyle = 'red';
로그인 후 복사
  18:     context.stroke();
로그인 후 복사

效果:

绘制一个复杂点的

   1: // 获取canvas 的ID
로그인 후 복사
로그인 후 복사
로그인 후 복사
로그인 후 복사
   2:     var canvas = document.getElementById('canvas');
로그인 후 복사
로그인 후 복사
로그인 후 복사
로그인 후 복사
   3:     if (canvas == null)
로그인 후 복사
로그인 후 복사
로그인 후 복사
로그인 후 복사
   4:     {
로그인 후 복사
로그인 후 복사
로그인 후 복사
로그인 후 복사
   5:         return false;
로그인 후 복사
로그인 후 복사
로그인 후 복사
로그인 후 복사
   6:     }
로그인 후 복사
로그인 후 복사
로그인 후 복사
로그인 후 복사
   7:     // 获取上下文
로그인 후 복사
로그인 후 복사
로그인 후 복사
로그인 후 복사
   8:     var context = canvas.getContext('2d');
로그인 후 복사
로그인 후 복사
로그인 후 복사
로그인 후 복사
   9:     // 设置填充的样式
로그인 후 복사
로그인 후 복사
로그인 후 복사
로그인 후 복사
  10:     context.fillStyle = "#eeeeff";
로그인 후 복사
로그인 후 복사
로그인 후 복사
로그인 후 복사
  11:     // 绘制矩形,以fillStyle填充
로그인 후 복사
로그인 후 복사
로그인 후 복사
로그인 후 복사
  12:     context.fillRect(0,0,400,300);
로그인 후 복사
로그인 후 복사
로그인 후 복사
로그인 후 복사
  13:     var dx = 150;
로그인 후 복사
로그인 후 복사
  14:     var dy = 150;
로그인 후 복사
로그인 후 복사
  15:     var s  = 100;
로그인 후 복사
로그인 후 복사
  16:      // 创建路径
로그인 후 복사
로그인 후 복사
  17:      context.beginPath();
로그인 후 복사
로그인 후 복사
  18:      context.fillStyle = 'rgb(100,255,100)';
로그인 후 복사
로그인 후 복사
  19:      context.strokeStyle = 'rgb(0,0100)';
로그인 후 복사
로그인 후 복사
  20:      var x = Math.sin(0);
로그인 후 복사
로그인 후 복사
  21:      var y = Math.cos(0);
로그인 후 복사
로그인 후 복사
  22:      var dig = Math.PI/15 *11;
로그인 후 복사
로그인 후 복사
  23:      for (var i = 0; i < 30; i++) {
로그인 후 복사
  24:          var x = Math.sin(i * dig);
로그인 후 복사
  25:          var y = Math.cos(i * dig);
로그인 후 복사
  26:          context.lineTo(dx+x*s,dx+y*s);
로그인 후 복사
  27:      }
로그인 후 복사
  28:      context.closePath();
로그인 후 복사
  29:      context.fill();
로그인 후 복사
  30:      context.stroke();
로그인 후 복사

效果:

4、绘制曲线:利用bezierCurveTo绘制贝济埃曲线

bezierCurveTo可以绘制曲线,是lineTo的曲线版本

   1: // 获取canvas 的ID
로그인 후 복사
로그인 후 복사
로그인 후 복사
로그인 후 복사
   2:     var canvas = document.getElementById('canvas');
로그인 후 복사
로그인 후 복사
로그인 후 복사
로그인 후 복사
   3:     if (canvas == null)
로그인 후 복사
로그인 후 복사
로그인 후 복사
로그인 후 복사
   4:     {
로그인 후 복사
로그인 후 복사
로그인 후 복사
로그인 후 복사
   5:         return false;
로그인 후 복사
로그인 후 복사
로그인 후 복사
로그인 후 복사
   6:     }
로그인 후 복사
로그인 후 복사
로그인 후 복사
로그인 후 복사
   7:     // 获取上下文
로그인 후 복사
로그인 후 복사
로그인 후 복사
로그인 후 복사
   8:     var context = canvas.getContext('2d');
로그인 후 복사
로그인 후 복사
로그인 후 복사
로그인 후 복사
   9:     // 设置填充的样式
로그인 후 복사
로그인 후 복사
로그인 후 복사
로그인 후 복사
  10:     context.fillStyle = "#eeeeff";
로그인 후 복사
로그인 후 복사
로그인 후 복사
로그인 후 복사
  11:     // 绘制矩形,以fillStyle填充
로그인 후 복사
로그인 후 복사
로그인 후 복사
로그인 후 복사
  12:     context.fillRect(0,0,400,300);
로그인 후 복사
로그인 후 복사
로그인 후 복사
로그인 후 복사
  13:     var dx = 150;
로그인 후 복사
로그인 후 복사
  14:     var dy = 150;
로그인 후 복사
로그인 후 복사
  15:     var s  = 100;
로그인 후 복사
로그인 후 복사
  16:      // 创建路径
로그인 후 복사
로그인 후 복사
  17:      context.beginPath();
로그인 후 복사
로그인 후 복사
  18:      context.fillStyle = 'rgb(100,255,100)';
로그인 후 복사
로그인 후 복사
  19:      context.strokeStyle = 'rgb(0,0100)';
로그인 후 복사
로그인 후 복사
  20:      var x = Math.sin(0);
로그인 후 복사
로그인 후 복사
  21:      var y = Math.cos(0);
로그인 후 복사
로그인 후 복사
  22:      var dig = Math.PI/15 *11;
로그인 후 복사
로그인 후 복사
  23:      context.moveTo(dx,dy);
로그인 후 복사
  24:      for (var i = 0; i < 30; i++) {
로그인 후 복사
  25:          var x = Math.sin(i * dig);
로그인 후 복사
  26:          var y = Math.cos(i * dig);
로그인 후 복사
  27:          context.bezierCurveTo(dx+x*s,dy+y*s-100,dx+x*s+100,dy+y*s,dx+x*s,dy+y*s);
로그인 후 복사
  28:      }
로그인 후 복사
  29:      context.closePath();
로그인 후 복사
  30:      context.fill();
로그인 후 복사
  31:      context.stroke();
로그인 후 복사

效果


 

下一篇:Canvas入门(2):图形渐变和图像形变换

 

원천:php.cn
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿