html5中文学习网

您的位置: 首页 > html5教程 > 入门教程 » 正文

HTML5 绘制图像(上)之:关于canvas元素引领下一代web页面的问题_html5教程技巧

[ ] 已经帮助:人解决问题
点评:HTML5新增了一个元素canvas,用于绘图使用,其实它的表现和div比较接近(其实他应该属于inline-block),而提供了许多接口,从而轻易的绘制矩形框、园三角形等
初识canvas元素

HTML5新增了一个元素canvas,用于绘图使用,其实它的表现和div比较接近(其实他应该属于inline-block),而提供了许多接口,从而轻易的绘制矩形框、园三角形等H4yHTML5中文学习网 - HTML5先行者学习网

PS:关于HTML5新增元素
经过最近两天的学习,和以前对HTML5的认知,我认为HTML5其实还是HTML4,两者之间没多大的区别,无非是增加了点新东西。H4yHTML5中文学习网 - HTML5先行者学习网
我认为HTML5为我们带来的真正意义是:我们可以用javascript做更多的事情了;我们可以用javascript实现更好的产品了。比如HTML5就解决了我们头疼的跨域问题、实时通信API、与现在的canvas之所以HTML5叫HTML5,我认为他是划时代的,比如他让我们用网页开发游戏变成可能;比如他让电脑桌面只剩IE不在是传说(过于夸张)
绘制矩形框

直入正题,我们来绘制一个矩形框看看,这里提供一个颜色选择器用于方便的选择颜色,PS:现在不用jquery编程感觉真麻烦。。。H4yHTML5中文学习网 - HTML5先行者学习网

 问题:定义样式与定义height与width

 一来就遇到了问题,我这里先来截个图:H4yHTML5中文学习网 - HTML5先行者学习网

复制代码
代码如下:
H4yHTML5中文学习网 - HTML5先行者学习网
<!DOCTYPE html> H4yHTML5中文学习网 - HTML5先行者学习网
<html xmlns="http://www.w3.org/1999/xhtml"> H4yHTML5中文学习网 - HTML5先行者学习网
<head> H4yHTML5中文学习网 - HTML5先行者学习网
<title></title> H4yHTML5中文学习网 - HTML5先行者学习网
<script type="text/javascript"> H4yHTML5中文学习网 - HTML5先行者学习网
function draw() { H4yHTML5中文学习网 - HTML5先行者学习网
//获取canvas对象 H4yHTML5中文学习网 - HTML5先行者学习网
var canvas = document.getElementById('canvas'); H4yHTML5中文学习网 - HTML5先行者学习网
if (canvas == null) { H4yHTML5中文学习网 - HTML5先行者学习网
return false; H4yHTML5中文学习网 - HTML5先行者学习网
} H4yHTML5中文学习网 - HTML5先行者学习网
var context = canvas.getContext('2d'); H4yHTML5中文学习网 - HTML5先行者学习网
context.fillStyle = '#99d9ea'; H4yHTML5中文学习网 - HTML5先行者学习网
context.fillRect(0, 0, 300, 200); //填充画布结束 H4yHTML5中文学习网 - HTML5先行者学习网
H4yHTML5中文学习网 - HTML5先行者学习网
context.strokeStyle = 'red'; H4yHTML5中文学习网 - HTML5先行者学习网
context.fillStyle = 'gray'; H4yHTML5中文学习网 - HTML5先行者学习网
context.lineWidth = 1; H4yHTML5中文学习网 - HTML5先行者学习网
context.fillRect(10, 10, 100, 100); H4yHTML5中文学习网 - HTML5先行者学习网
context.strokeRect(10, 10, 100, 100); H4yHTML5中文学习网 - HTML5先行者学习网
H4yHTML5中文学习网 - HTML5先行者学习网
context.clearRect(20, 20, 20, 20); H4yHTML5中文学习网 - HTML5先行者学习网
} H4yHTML5中文学习网 - HTML5先行者学习网
</script> H4yHTML5中文学习网 - HTML5先行者学习网
</head> H4yHTML5中文学习网 - HTML5先行者学习网
<body> H4yHTML5中文学习网 - HTML5先行者学习网
<canvas id="canvas" width=300 height="200" style="border: 1px solid black; width: 300px; height: 200px;"> H4yHTML5中文学习网 - HTML5先行者学习网
</canvas> H4yHTML5中文学习网 - HTML5先行者学习网
H4yHTML5中文学习网 - HTML5先行者学习网
H4yHTML5中文学习网 - HTML5先行者学习网
<button onclick="draw();"> H4yHTML5中文学习网 - HTML5先行者学习网
绘制矩形</button> H4yHTML5中文学习网 - HTML5先行者学习网
<input type="color" /> H4yHTML5中文学习网 - HTML5先行者学习网
</body> H4yHTML5中文学习网 - HTML5先行者学习网
</html>H4yHTML5中文学习网 - HTML5先行者学习网
H4yHTML5中文学习网 - HTML5先行者学习网
H4yHTML5中文学习网 - HTML5先行者学习网

  各位情况canvas元素,图一位设置width与height的情况,图二十用style指定的情况:H4yHTML5中文学习网 - HTML5先行者学习网

H4yHTML5中文学习网 - HTML5先行者学习网

可以看到,对于canvas来说,还是老老实实定义高宽的好,别去傻乎乎的用样式了,当然这个问题需要实际研究才能得出最终结论。H4yHTML5中文学习网 - HTML5先行者学习网

好了,现在我们再来看看绘制矩形这个方法:H4yHTML5中文学习网 - HTML5先行者学习网

PS:其实,使用该方法这么麻烦,完全可以将该函数封装下下,使用便会简单许多
1、使用getElementById方法获取绘制对象2、取得上下文getContext('2d'),这都是固定的写法3、指定填充的颜色fillStyle和绘制的颜色strokeStyle,即里面的颜色和边框的颜色4、指定线宽linewidth5、填充/绘制 fillRect/strokeRect 参数为 x,y,width,height6、若是要使其中一块透明,使用clearRect

至此,绘制矩形框便暂时告一段落。H4yHTML5中文学习网 - HTML5先行者学习网

绘制圆形 H4yHTML5中文学习网 - HTML5先行者学习网

现在我们来绘制圆形,这个说起绘制圆形,其实我原来用js好像写过一个,这里也贴出来看看:H4yHTML5中文学习网 - HTML5先行者学习网

复制代码
代码如下:
H4yHTML5中文学习网 - HTML5先行者学习网
我是纯js画的圆 H4yHTML5中文学习网 - HTML5先行者学习网
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">H4yHTML5中文学习网 - HTML5先行者学习网
<html xmlns="http://www.w3.org/1999/xhtml">H4yHTML5中文学习网 - HTML5先行者学习网
<head>H4yHTML5中文学习网 - HTML5先行者学习网
<title></title>H4yHTML5中文学习网 - HTML5先行者学习网
<style type="text/css">H4yHTML5中文学习网 - HTML5先行者学习网
divH4yHTML5中文学习网 - HTML5先行者学习网
{H4yHTML5中文学习网 - HTML5先行者学习网
position: absolute;H4yHTML5中文学习网 - HTML5先行者学习网
width: 1px;H4yHTML5中文学习网 - HTML5先行者学习网
height: 1px;H4yHTML5中文学习网 - HTML5先行者学习网
line-height: 1px;H4yHTML5中文学习网 - HTML5先行者学习网
}H4yHTML5中文学习网 - HTML5先行者学习网
</style>H4yHTML5中文学习网 - HTML5先行者学习网
<script src="http://www.cnblogs.com/jquery-1.7.1.js" type="text/javascript"></script>H4yHTML5中文学习网 - HTML5先行者学习网
<script type="text/javascript">H4yHTML5中文学习网 - HTML5先行者学习网
//x2 + y2 = r2;H4yHTML5中文学习网 - HTML5先行者学习网
$(document).ready(function () {H4yHTML5中文学习网 - HTML5先行者学习网
//先画x,yH4yHTML5中文学习网 - HTML5先行者学习网
var box = $('#box');H4yHTML5中文学习网 - HTML5先行者学习网
var NUM = 200;H4yHTML5中文学习网 - HTML5先行者学习网
var R = NUM / 2;H4yHTML5中文学习网 - HTML5先行者学习网
var RR = R * R;H4yHTML5中文学习网 - HTML5先行者学习网
for (var i = 0; i <= NUM; i = i + 6) {H4yHTML5中文学习网 - HTML5先行者学习网
//var divX = $('<div style="left:' + i + 'px;top:' + R + 'px;">*</div>')H4yHTML5中文学习网 - HTML5先行者学习网
// var divY = $('<div style="top:' + i + 'px;left:' + R + 'px;">*</div>')H4yHTML5中文学习网 - HTML5先行者学习网
H4yHTML5中文学习网 - HTML5先行者学习网
var ti = i;H4yHTML5中文学习网 - HTML5先行者学习网
//sqrt(x)H4yHTML5中文学习网 - HTML5先行者学习网
if (ti > R) {H4yHTML5中文学习网 - HTML5先行者学习网
ti = ti - R;H4yHTML5中文学习网 - HTML5先行者学习网
var ty = Math.sqrt((RR - ti * ti));H4yHTML5中文学习网 - HTML5先行者学习网
var y = $('<div style="left:' + (R - ty) + 'px;top:' + i + 'px;">*</div>')H4yHTML5中文学习网 - HTML5先行者学习网
var y1 = $('<div style="left:' + (R + ty) + 'px;top:' + i + 'px;">*</div>')H4yHTML5中文学习网 - HTML5先行者学习网
box.append(y);H4yHTML5中文学习网 - HTML5先行者学习网
box.append(y1);H4yHTML5中文学习网 - HTML5先行者学习网
} else if (ti < R) {H4yHTML5中文学习网 - HTML5先行者学习网
ti = R - ti;H4yHTML5中文学习网 - HTML5先行者学习网
var ty = Math.sqrt((RR - ti * ti));H4yHTML5中文学习网 - HTML5先行者学习网
var y = $('<div style="left:' + (R - ty) + 'px;top:' + i + 'px;">*</div>')H4yHTML5中文学习网 - HTML5先行者学习网
var y1 = $('<div style="left:' + (R + ty) + 'px;top:' + i + 'px;">*</div>')H4yHTML5中文学习网 - HTML5先行者学习网
box.append(y);H4yHTML5中文学习网 - HTML5先行者学习网
box.append(y1);H4yHTML5中文学习网 - HTML5先行者学习网
}H4yHTML5中文学习网 - HTML5先行者学习网
//box.append(divX);H4yHTML5中文学习网 - HTML5先行者学习网
//box.append(divY);H4yHTML5中文学习网 - HTML5先行者学习网
}H4yHTML5中文学习网 - HTML5先行者学习网
H4yHTML5中文学习网 - HTML5先行者学习网
for (var i = 0; i <= NUM; i = i + 6) {H4yHTML5中文学习网 - HTML5先行者学习网
//var divX = $('<div style="left:' + i + 'px;top:' + R + 'px;">*</div>')H4yHTML5中文学习网 - HTML5先行者学习网
// var divY = $('<div style="top:' + i + 'px;left:' + R + 'px;">*</div>')H4yHTML5中文学习网 - HTML5先行者学习网
var ti = i;H4yHTML5中文学习网 - HTML5先行者学习网
//sqrt(x)H4yHTML5中文学习网 - HTML5先行者学习网
if (ti > R) {H4yHTML5中文学习网 - HTML5先行者学习网
ti = ti - R;H4yHTML5中文学习网 - HTML5先行者学习网
var ty = Math.sqrt((RR - ti * ti));H4yHTML5中文学习网 - HTML5先行者学习网
var y = $('<div style="top:' + (R - ty) + 'px;left:' + i + 'px;">*</div>')H4yHTML5中文学习网 - HTML5先行者学习网
var y1 = $('<div style="top:' + (R + ty) + 'px;left:' + i + 'px;">*</div>')H4yHTML5中文学习网 - HTML5先行者学习网
box.append(y);H4yHTML5中文学习网 - HTML5先行者学习网
box.append(y1);H4yHTML5中文学习网 - HTML5先行者学习网
} else if (ti < R) {H4yHTML5中文学习网 - HTML5先行者学习网
ti = R - ti;H4yHTML5中文学习网 - HTML5先行者学习网
var ty = Math.sqrt((RR - ti * ti));H4yHTML5中文学习网 - HTML5先行者学习网
var y = $('<div style="top:' + (R - ty) + 'px;left:' + i + 'px;">*</div>')H4yHTML5中文学习网 - HTML5先行者学习网
var y1 = $('<div style="top:' + (R + ty) + 'px;left:' + i + 'px;">*</div>')H4yHTML5中文学习网 - HTML5先行者学习网
box.append(y);H4yHTML5中文学习网 - HTML5先行者学习网
box.append(y1);H4yHTML5中文学习网 - HTML5先行者学习网
}H4yHTML5中文学习网 - HTML5先行者学习网
}H4yHTML5中文学习网 - HTML5先行者学习网
});H4yHTML5中文学习网 - HTML5先行者学习网
H4yHTML5中文学习网 - HTML5先行者学习网
</script>H4yHTML5中文学习网 - HTML5先行者学习网
</head>H4yHTML5中文学习网 - HTML5先行者学习网
<body>H4yHTML5中文学习网 - HTML5先行者学习网
<div id="box" style="width: 504px; height: 504px; position: relative; top: 20px;H4yHTML5中文学习网 - HTML5先行者学习网
left: 300px; border: 0px solid black;">H4yHTML5中文学习网 - HTML5先行者学习网
</div>H4yHTML5中文学习网 - HTML5先行者学习网
</body>H4yHTML5中文学习网 - HTML5先行者学习网
</html>H4yHTML5中文学习网 - HTML5先行者学习网
H4yHTML5中文学习网 - HTML5先行者学习网
H4yHTML5中文学习网 - HTML5先行者学习网

H4yHTML5中文学习网 - HTML5先行者学习网

话说,他还是比较圆的说。。。H4yHTML5中文学习网 - HTML5先行者学习网

进入正题 H4yHTML5中文学习网 - HTML5先行者学习网

说起画圆、正弦图等肯定会经过一定计算的,所以稍稍复杂点:H4yHTML5中文学习网 - HTML5先行者学习网

① 创建路径H4yHTML5中文学习网 - HTML5先行者学习网

② 创建图形路径H4yHTML5中文学习网 - HTML5先行者学习网

③ 路径创建完成后关闭路径H4yHTML5中文学习网 - HTML5先行者学习网

④ 设定绘制样式调用方法绘制之H4yHTML5中文学习网 - HTML5先行者学习网

复制代码
代码如下:
H4yHTML5中文学习网 - HTML5先行者学习网
我是一个圆 H4yHTML5中文学习网 - HTML5先行者学习网
<!DOCTYPE html>H4yHTML5中文学习网 - HTML5先行者学习网
<html xmlns="http://www.w3.org/1999/xhtml">H4yHTML5中文学习网 - HTML5先行者学习网
<head>H4yHTML5中文学习网 - HTML5先行者学习网
<title></title>H4yHTML5中文学习网 - HTML5先行者学习网
<script type="text/javascript">H4yHTML5中文学习网 - HTML5先行者学习网
function draw() {H4yHTML5中文学习网 - HTML5先行者学习网
//获取canvas对象H4yHTML5中文学习网 - HTML5先行者学习网
var canvas = document.getElementById('canvas');H4yHTML5中文学习网 - HTML5先行者学习网
if (canvas == null) {H4yHTML5中文学习网 - HTML5先行者学习网
return false;H4yHTML5中文学习网 - HTML5先行者学习网
}H4yHTML5中文学习网 - HTML5先行者学习网
var context = canvas.getContext('2d');H4yHTML5中文学习网 - HTML5先行者学习网
context.fillStyle = '#99d9ea';H4yHTML5中文学习网 - HTML5先行者学习网
context.fillRect(0, 0, 300, 200); //填充画布结束H4yHTML5中文学习网 - HTML5先行者学习网
for (var i = 0; i < 5; i++) {H4yHTML5中文学习网 - HTML5先行者学习网
context.beginPath();H4yHTML5中文学习网 - HTML5先行者学习网
context.arc(i * 25, i * 25, i * 10, 0, Math.PI * 2, true);H4yHTML5中文学习网 - HTML5先行者学习网
context.closePath();H4yHTML5中文学习网 - HTML5先行者学习网
context.strokeStyle = 'red';H4yHTML5中文学习网 - HTML5先行者学习网
context.fill();H4yHTML5中文学习网 - HTML5先行者学习网
}H4yHTML5中文学习网 - HTML5先行者学习网
}H4yHTML5中文学习网 - HTML5先行者学习网
</script>H4yHTML5中文学习网 - HTML5先行者学习网
</head>H4yHTML5中文学习网 - HTML5先行者学习网
<body>H4yHTML5中文学习网 - HTML5先行者学习网
<canvas id="canvas" width="300" height="200" >H4yHTML5中文学习网 - HTML5先行者学习网
</canvas>H4yHTML5中文学习网 - HTML5先行者学习网
H4yHTML5中文学习网 - HTML5先行者学习网
<button onclick="draw();">H4yHTML5中文学习网 - HTML5先行者学习网
绘制圆</button>H4yHTML5中文学习网 - HTML5先行者学习网
<input type="color" />H4yHTML5中文学习网 - HTML5先行者学习网
</body>H4yHTML5中文学习网 - HTML5先行者学习网
</html>H4yHTML5中文学习网 - HTML5先行者学习网
H4yHTML5中文学习网 - HTML5先行者学习网
H4yHTML5中文学习网 - HTML5先行者学习网

H4yHTML5中文学习网 - HTML5先行者学习网

我们来看看绘制圆过程中其它地方都没有问题,但是创建圆路径这块值得考虑:H4yHTML5中文学习网 - HTML5先行者学习网

arc方法参数很多,依次是:xy半径开始弧度(我们一般喜欢角度,所以要转换)结束弧度顺时针或者逆时针true为顺时针H4yHTML5中文学习网 - HTML5先行者学习网
其它都好说,主要这个开始角度和结束角度我们来研究下,因为开始我没搞懂,但后来我发现他其实很简单了。。。就是开始的角度和结束的角度嘛,和我们高中学的知识一样的,只不过单位换算Math.PI/180为一度。。。。H4yHTML5中文学习网 - HTML5先行者学习网
反正还是没说清楚,对了,记得我们高中画圆的除了圆规和一个计量三角形角度的半圆直尺了吗,我要说的角度就是那个。。。太坑爹了!H4yHTML5中文学习网 - HTML5先行者学习网
好像最右边是0度,垂直是90度,水平是180度,既然如此,我们再来看看H4yHTML5中文学习网 - HTML5先行者学习网

复制代码
代码如下:
H4yHTML5中文学习网 - HTML5先行者学习网
正时针逆时针 H4yHTML5中文学习网 - HTML5先行者学习网
<!DOCTYPE html>H4yHTML5中文学习网 - HTML5先行者学习网
<html xmlns="http://www.w3.org/1999/xhtml">H4yHTML5中文学习网 - HTML5先行者学习网
<head>H4yHTML5中文学习网 - HTML5先行者学习网
<title></title>H4yHTML5中文学习网 - HTML5先行者学习网
<script type="text/javascript">H4yHTML5中文学习网 - HTML5先行者学习网
function draw() {H4yHTML5中文学习网 - HTML5先行者学习网
//获取canvas对象H4yHTML5中文学习网 - HTML5先行者学习网
var canvas = document.getElementById('canvas');H4yHTML5中文学习网 - HTML5先行者学习网
if (canvas == null) {H4yHTML5中文学习网 - HTML5先行者学习网
return false;H4yHTML5中文学习网 - HTML5先行者学习网
}H4yHTML5中文学习网 - HTML5先行者学习网
var context = canvas.getContext('2d');H4yHTML5中文学习网 - HTML5先行者学习网
context.fillStyle = '#99d9ea';H4yHTML5中文学习网 - HTML5先行者学习网
context.fillRect(0, 0, 400, 300); //填充画布结束H4yHTML5中文学习网 - HTML5先行者学习网
H4yHTML5中文学习网 - HTML5先行者学习网
context.beginPath();H4yHTML5中文学习网 - HTML5先行者学习网
context.arc(80, 80, 50, 0, 180 * Math.PI / 180, true);H4yHTML5中文学习网 - HTML5先行者学习网
context.closePath();H4yHTML5中文学习网 - HTML5先行者学习网
context.fillStyle = 'gray';H4yHTML5中文学习网 - HTML5先行者学习网
context.fill();H4yHTML5中文学习网 - HTML5先行者学习网
H4yHTML5中文学习网 - HTML5先行者学习网
context.beginPath();H4yHTML5中文学习网 - HTML5先行者学习网
context.arc(180, 180, 50, 0, 180 * Math.PI / 180, false);H4yHTML5中文学习网 - HTML5先行者学习网
context.closePath();H4yHTML5中文学习网 - HTML5先行者学习网
context.fillStyle = 'gray';H4yHTML5中文学习网 - HTML5先行者学习网
context.fill();H4yHTML5中文学习网 - HTML5先行者学习网
H4yHTML5中文学习网 - HTML5先行者学习网
H4yHTML5中文学习网 - HTML5先行者学习网
}H4yHTML5中文学习网 - HTML5先行者学习网
</script>H4yHTML5中文学习网 - HTML5先行者学习网
</head>H4yHTML5中文学习网 - HTML5先行者学习网
<body>H4yHTML5中文学习网 - HTML5先行者学习网
<canvas id="canvas" width="400" height="300">H4yHTML5中文学习网 - HTML5先行者学习网
</canvas>H4yHTML5中文学习网 - HTML5先行者学习网
H4yHTML5中文学习网 - HTML5先行者学习网
<button onclick="draw();">H4yHTML5中文学习网 - HTML5先行者学习网
绘制圆</button>H4yHTML5中文学习网 - HTML5先行者学习网
<input type="color" />H4yHTML5中文学习网 - HTML5先行者学习网
</body>H4yHTML5中文学习网 - HTML5先行者学习网
</html>H4yHTML5中文学习网 - HTML5先行者学习网
H4yHTML5中文学习网 - HTML5先行者学习网

H4yHTML5中文学习网 - HTML5先行者学习网

我们发现正时针与逆时针还是有所不同的,H4yHTML5中文学习网 - HTML5先行者学习网

 context.arc(180, 180, 50, 90 * Math.PI / 180, 290 * Math.PI / 180, true);

原谅我这里居然思考了半个小时,我甚至搜索了高中的资料。。。。H4yHTML5中文学习网 - HTML5先行者学习网
H4yHTML5中文学习网 - HTML5先行者学习网

于是我好像明白了点什么。。。。。。H4yHTML5中文学习网 - HTML5先行者学习网

moveTo与lineTo

现上实验结果:H4yHTML5中文学习网 - HTML5先行者学习网

复制代码
代码如下:
H4yHTML5中文学习网 - HTML5先行者学习网
两次moveto H4yHTML5中文学习网 - HTML5先行者学习网
<!DOCTYPE html>H4yHTML5中文学习网 - HTML5先行者学习网
<html xmlns="http://www.w3.org/1999/xhtml">H4yHTML5中文学习网 - HTML5先行者学习网
<head>H4yHTML5中文学习网 - HTML5先行者学习网
<title></title>H4yHTML5中文学习网 - HTML5先行者学习网
<script type="text/javascript">H4yHTML5中文学习网 - HTML5先行者学习网
function draw() {H4yHTML5中文学习网 - HTML5先行者学习网
//获取canvas对象H4yHTML5中文学习网 - HTML5先行者学习网
var canvas = document.getElementById('canvas');H4yHTML5中文学习网 - HTML5先行者学习网
if (canvas == null) {H4yHTML5中文学习网 - HTML5先行者学习网
return false;H4yHTML5中文学习网 - HTML5先行者学习网
}H4yHTML5中文学习网 - HTML5先行者学习网
var context = canvas.getContext('2d');H4yHTML5中文学习网 - HTML5先行者学习网
context.fillStyle = '#99d9ea';H4yHTML5中文学习网 - HTML5先行者学习网
context.fillRect(0, 0, 300, 200); //填充画布结束H4yHTML5中文学习网 - HTML5先行者学习网
H4yHTML5中文学习网 - HTML5先行者学习网
context.beginPath();H4yHTML5中文学习网 - HTML5先行者学习网
context.fillStyle = 'gray';H4yHTML5中文学习网 - HTML5先行者学习网
context.strokeStyle = 'black';H4yHTML5中文学习网 - HTML5先行者学习网
H4yHTML5中文学习网 - HTML5先行者学习网
context.moveTo(10, 10);H4yHTML5中文学习网 - HTML5先行者学习网
context.lineTo(150, 150);H4yHTML5中文学习网 - HTML5先行者学习网
H4yHTML5中文学习网 - HTML5先行者学习网
context.moveTo(10, 10);H4yHTML5中文学习网 - HTML5先行者学习网
context.lineTo(10, 150);H4yHTML5中文学习网 - HTML5先行者学习网
H4yHTML5中文学习网 - HTML5先行者学习网
context.closePath();H4yHTML5中文学习网 - HTML5先行者学习网
context.fill();H4yHTML5中文学习网 - HTML5先行者学习网
context.stroke();H4yHTML5中文学习网 - HTML5先行者学习网
H4yHTML5中文学习网 - HTML5先行者学习网
}H4yHTML5中文学习网 - HTML5先行者学习网
</script>H4yHTML5中文学习网 - HTML5先行者学习网
</head>H4yHTML5中文学习网 - HTML5先行者学习网
<body>H4yHTML5中文学习网 - HTML5先行者学习网
<canvas id="canvas" width="300" height="200">H4yHTML5中文学习网 - HTML5先行者学习网
</canvas>H4yHTML5中文学习网 - HTML5先行者学习网
H4yHTML5中文学习网 - HTML5先行者学习网
<button onclick="draw();">H4yHTML5中文学习网 - HTML5先行者学习网
绘制</button>H4yHTML5中文学习网 - HTML5先行者学习网
<input type="color" />H4yHTML5中文学习网 - HTML5先行者学习网
</body>H4yHTML5中文学习网 - HTML5先行者学习网
</html>H4yHTML5中文学习网 - HTML5先行者学习网
H4yHTML5中文学习网 - HTML5先行者学习网

复制代码
代码如下:
H4yHTML5中文学习网 - HTML5先行者学习网
一次moveto H4yHTML5中文学习网 - HTML5先行者学习网
<!DOCTYPE html>H4yHTML5中文学习网 - HTML5先行者学习网
<html xmlns="http://www.w3.org/1999/xhtml">H4yHTML5中文学习网 - HTML5先行者学习网
<head>H4yHTML5中文学习网 - HTML5先行者学习网
<title></title>H4yHTML5中文学习网 - HTML5先行者学习网
<script type="text/javascript">H4yHTML5中文学习网 - HTML5先行者学习网
function draw() {H4yHTML5中文学习网 - HTML5先行者学习网
//获取canvas对象H4yHTML5中文学习网 - HTML5先行者学习网
var canvas = document.getElementById('canvas');H4yHTML5中文学习网 - HTML5先行者学习网
if (canvas == null) {H4yHTML5中文学习网 - HTML5先行者学习网
return false;H4yHTML5中文学习网 - HTML5先行者学习网
}H4yHTML5中文学习网 - HTML5先行者学习网
var context = canvas.getContext('2d');H4yHTML5中文学习网 - HTML5先行者学习网
context.fillStyle = '#99d9ea';H4yHTML5中文学习网 - HTML5先行者学习网
context.fillRect(0, 0, 300, 200); //填充画布结束H4yHTML5中文学习网 - HTML5先行者学习网
H4yHTML5中文学习网 - HTML5先行者学习网
context.beginPath();H4yHTML5中文学习网 - HTML5先行者学习网
context.fillStyle = 'gray';H4yHTML5中文学习网 - HTML5先行者学习网
context.strokeStyle = 'black';H4yHTML5中文学习网 - HTML5先行者学习网
H4yHTML5中文学习网 - HTML5先行者学习网
context.moveTo(10, 10);H4yHTML5中文学习网 - HTML5先行者学习网
context.lineTo(150, 150);H4yHTML5中文学习网 - HTML5先行者学习网
H4yHTML5中文学习网 - HTML5先行者学习网
// context.moveTo(10, 10);H4yHTML5中文学习网 - HTML5先行者学习网
context.lineTo(10, 150);H4yHTML5中文学习网 - HTML5先行者学习网
H4yHTML5中文学习网 - HTML5先行者学习网
context.closePath();H4yHTML5中文学习网 - HTML5先行者学习网
context.fill();H4yHTML5中文学习网 - HTML5先行者学习网
context.stroke();H4yHTML5中文学习网 - HTML5先行者学习网
H4yHTML5中文学习网 - HTML5先行者学习网
}H4yHTML5中文学习网 - HTML5先行者学习网
</script>H4yHTML5中文学习网 - HTML5先行者学习网
</head>H4yHTML5中文学习网 - HTML5先行者学习网
<body>H4yHTML5中文学习网 - HTML5先行者学习网
<canvas id="canvas" width="300" height="200">H4yHTML5中文学习网 - HTML5先行者学习网
</canvas>H4yHTML5中文学习网 - HTML5先行者学习网
H4yHTML5中文学习网 - HTML5先行者学习网
<button onclick="draw();">H4yHTML5中文学习网 - HTML5先行者学习网
绘制</button>H4yHTML5中文学习网 - HTML5先行者学习网
<input type="color" />H4yHTML5中文学习网 - HTML5先行者学习网
</body>H4yHTML5中文学习网 - HTML5先行者学习网
</html>H4yHTML5中文学习网 - HTML5先行者学习网
H4yHTML5中文学习网 - HTML5先行者学习网

复制代码
代码如下:
H4yHTML5中文学习网 - HTML5先行者学习网
三次moveto H4yHTML5中文学习网 - HTML5先行者学习网
<!DOCTYPE html>H4yHTML5中文学习网 - HTML5先行者学习网
<html xmlns="http://www.w3.org/1999/xhtml">H4yHTML5中文学习网 - HTML5先行者学习网
<head>H4yHTML5中文学习网 - HTML5先行者学习网
<title></title>H4yHTML5中文学习网 - HTML5先行者学习网
<script type="text/javascript">H4yHTML5中文学习网 - HTML5先行者学习网
function draw() {H4yHTML5中文学习网 - HTML5先行者学习网
//获取canvas对象H4yHTML5中文学习网 - HTML5先行者学习网
var canvas = document.getElementById('canvas');H4yHTML5中文学习网 - HTML5先行者学习网
if (canvas == null) {H4yHTML5中文学习网 - HTML5先行者学习网
return false;H4yHTML5中文学习网 - HTML5先行者学习网
}H4yHTML5中文学习网 - HTML5先行者学习网
var context = canvas.getContext('2d');H4yHTML5中文学习网 - HTML5先行者学习网
context.fillStyle = '#99d9ea';H4yHTML5中文学习网 - HTML5先行者学习网
context.fillRect(0, 0, 300, 200); //填充画布结束H4yHTML5中文学习网 - HTML5先行者学习网
H4yHTML5中文学习网 - HTML5先行者学习网
context.beginPath();H4yHTML5中文学习网 - HTML5先行者学习网
context.fillStyle = 'gray';H4yHTML5中文学习网 - HTML5先行者学习网
context.strokeStyle = 'black';H4yHTML5中文学习网 - HTML5先行者学习网
H4yHTML5中文学习网 - HTML5先行者学习网
context.moveTo(10, 10);H4yHTML5中文学习网 - HTML5先行者学习网
context.lineTo(150, 150);H4yHTML5中文学习网 - HTML5先行者学习网
H4yHTML5中文学习网 - HTML5先行者学习网
context.moveTo(10, 10);H4yHTML5中文学习网 - HTML5先行者学习网
context.lineTo(10, 150);H4yHTML5中文学习网 - HTML5先行者学习网
H4yHTML5中文学习网 - HTML5先行者学习网
context.moveTo(10, 150);H4yHTML5中文学习网 - HTML5先行者学习网
context.lineTo(150, 150);H4yHTML5中文学习网 - HTML5先行者学习网
H4yHTML5中文学习网 - HTML5先行者学习网
context.closePath();H4yHTML5中文学习网 - HTML5先行者学习网
context.fill();H4yHTML5中文学习网 - HTML5先行者学习网
context.stroke();H4yHTML5中文学习网 - HTML5先行者学习网
H4yHTML5中文学习网 - HTML5先行者学习网
}H4yHTML5中文学习网 - HTML5先行者学习网
</script>H4yHTML5中文学习网 - HTML5先行者学习网
</head>H4yHTML5中文学习网 - HTML5先行者学习网
<body>H4yHTML5中文学习网 - HTML5先行者学习网
<canvas id="canvas" width="300" height="200">H4yHTML5中文学习网 - HTML5先行者学习网
</canvas>H4yHTML5中文学习网 - HTML5先行者学习网
H4yHTML5中文学习网 - HTML5先行者学习网
<button onclick="draw();">H4yHTML5中文学习网 - HTML5先行者学习网
绘制</button>H4yHTML5中文学习网 - HTML5先行者学习网
<input type="color" />H4yHTML5中文学习网 - HTML5先行者学习网
</body>H4yHTML5中文学习网 - HTML5先行者学习网
</html>H4yHTML5中文学习网 - HTML5先行者学习网
H4yHTML5中文学习网 - HTML5先行者学习网
H4yHTML5中文学习网 - HTML5先行者学习网

以上代码几乎一样,但是他产生的结果却不同:H4yHTML5中文学习网 - HTML5先行者学习网
H4yHTML5中文学习网 - HTML5先行者学习网

我认为,使用moveto后相当于新开一起点,之前的一笔勾销,若是只使用lineto的话,他会将几个点连成线,若是可以组成图形便会拥有中间色彩
H4yHTML5中文学习网 - HTML5先行者学习网
(责任编辑:)
推荐书籍
推荐资讯
关于HTML5先行者 - 联系我们 - 广告服务 - 友情链接 - 网站地图 - 版权声明 - 人才招聘 - 帮助