canvas绘制直线多边形(二)

在绘制之前,依据上一节所说的内容获取context  2维画布

1  context.moveTo(x,y);    定义绘图开始
2  context.lintTo(x1,y1);   定义线条画到的位置
3  context.lineWidth=5;       //线条宽度
4  context.strokeStyle="red"   //线条颜色
5  context.stroke();   //用于绘制线条

 

利用上述代码我们可以绘制一条,从(x,y)坐标开始,到(x1,y1)结束的宽5个像素,颜色为红色的直线    这里的x,y坐标是相对于画布的左上角坐标来看的。

 

 

当然我们可以画线了,当然可以利用线条画出多边形,就像在纸上绘制一样

1     context.moveTo(100,100);
2     context.lineTo(700,700);
3     context.lineTo(100,700);
4     context.lineTo(100,100);
5     context.lineWidth=5;       //线条宽度
6     context.strokeStyle="red"   //线条颜色
7     context.stroke();   //用于绘制线条

 

就是利用lineto函数像不同的点延伸直线而已,以上代码就绘制出了一个三角形

 

 

现在多边形已经画好了,我们希望可以填充颜色,

1   context.fillStyle="#000";    //用于填充色
2   context.fill();

我们只要利用fillStyle指定颜色,这里的颜色指定和css颜色指定是一样的

然后fill()绘制一下就ok了

 

 

一张画布当然不会只画一个图形了,我们如何去其他位置在画一个图形呢?

有人会说,直接利用moveto   移动到某个像素点,在用lineto进行绘制就行了呗,就像下面代码一样

 1     context.moveTo(100,100);
 2     context.lineTo(700,700);
 3     context.lineTo(100,700);
 4     context.lineTo(100,100);
 5     context.lineWidth=5;       //线条宽度
 6     context.strokeStyle="red"   //线条颜色
 7     context.stroke();   //用于绘制线条
 8    
 9     context.fillStyle="#000";    //用于填充色
10     context.fill();
11    
12     context.moveTo(200,100);
13     context.lineTo(800,700);
14     context.strokeStyle="blue";
15     context.stroke();

我们可以看到,虽然三角形的边框颜色我们设置的是  红色,线条的颜色是蓝色,可是绘制完之后发现,不论边框还是线条都是蓝色。

 

这就是canvas绘制机制是基于状态的绘图

简单来说对线条,或则填充色的指定都是一种状态,后面相同的种类(颜色,线条宽度。。)的指定会覆盖前面的,这里蓝色的指定覆盖了红色,我们要怎么做呢?

 1     context.beginPath();
 2     context.moveTo(100,100);
 3     context.lineTo(700,700);
 4     context.lineTo(100,700);
 5     context.lineTo(100,100);
 6     context.closePath();
 7     context.lineWidth=5;       //线条宽度
 8     context.strokeStyle="red"   //线条颜色
 9     context.stroke();   //用于绘制线条
10    
11     context.fillStyle="#000";    //用于填充色
12     context.fill();
13     context.beginPath();
14     context.moveTo(200,100);
15     context.lineTo(800,700);
16     context.closePath();
17     context.strokeStyle="blue";
18     context.stroke();

 

我们只要加上beginPath和closepath把绘制线路(线条,多边形,,,)包裹起来,就可以指定包裹部分后面靠的最近的部分状态会对其起作用。

beginPath表示开始,开始绘制的图形将于前面的绘制毫无关系,只会听从后面beginPath之前的状态

closePath表示结束,结束这段绘制,如果是曲线,会用直线封闭这段曲线,这里不写,不印象状态的绘制

 

完整代码

 1 <!DOCTYPE html>
 2 <html>
 3     <head>
 4         <meta charset="utf-8" />
 5         <title></title>
 6     </head>
 7     <body>
 8         
 9         <canvas id="canvas" width="400" height="400" style="border: 1px solid #aaa;display:block;margin: auto;">你的浏览器不支持</canvas>
10         
11         <script>
12             window.onload=function(){
13                 var canvas=document.getElementById("canvas");
14             /*    canvas.width=100;
15                 canvas.height=100;    //在此处定义canvas的宽高*/
16                 var context=canvas.getContext('2d');
17                 
18                 //基于context绘制
19                 context.beginPath();
20                 context.moveTo(100,100);
21                 context.lineTo(700,700);
22                 context.lineTo(100,700);
23                 context.lineTo(100,100);
24                 context.closePath();
25                 context.lineWidth=5;       //线条宽度
26                 context.strokeStyle="red"   //线条颜色
27                 context.stroke();   //用于绘制线条
28                 
29                 context.fillStyle="#000";    //用于填充色
30                 context.fill(); 
31                 context.beginPath();
32                 context.moveTo(200,100);
33                 context.lineTo(800,700);
34                 context.closePath();
35                 context.strokeStyle="blue";
36                 context.stroke();
37                 context.fillStyle="red";    //用于填充色
38                 context.fill();     
39                 
40             }
41                 
42         </script>
43     </body>
44 </html>

 

 

下一节,我们将会说,弧和圆的绘制。

 

 

 

 

 

posted @ 2015-01-29 20:38  mangues  阅读(2239)  评论(2编辑  收藏  举报