点评:我们可以使用“路径”来描画任何图形。路径,简单来说就是一系列的点以及连接这些点的线。任何Canvas上下文只会有一个“当前路径”,而当context.save()调用时,该“当前路径”并不会被保存
原文: aTgHTML5中文学习网 - HTML5先行者学习网http://www.lifelaf.com/blog/?p=371
aTgHTML5中文学习网 - HTML5先行者学习网本文翻译自Steve Fulton & Jeff Fulton HTML5 Canvas, Chapter 2, “Using Paths to Create Lines”
aTgHTML5中文学习网 - HTML5先行者学习网aTgHTML5中文学习网 - HTML5先行者学习网对于HTML5 Canvas,我们可以使用“路径”来描画任何图形。路径,简单来说就是一系列的点以及连接这些点的线。任何Canvas上下文只会有一个“当前路径”,而当context.save()调用时,该“当前路径”并不会被保存。
aTgHTML5中文学习网 - HTML5先行者学习网aTgHTML5中文学习网 - HTML5先行者学习网路径的开始与结束 aTgHTML5中文学习网 - HTML5先行者学习网aTgHTML5中文学习网 - HTML5先行者学习网调用beginPath()可以开始一个路径,而调用closePath()则会令该路径结束。如果连接路径中的点,那么这种连接就构成了一个“子路径”。如果“子路径”中最后一个点与其自身的第一个点相连,我们就认为该“子路径”是“闭合”的。
aTgHTML5中文学习网 - HTML5先行者学习网aTgHTML5中文学习网 - HTML5先行者学习网线条的描绘 aTgHTML5中文学习网 - HTML5先行者学习网aTgHTML5中文学习网 - HTML5先行者学习网最基本的路径操作由反复调用moveTo()和lineTo()命令组成。比如以下这个例子:
aTgHTML5中文学习网 - HTML5先行者学习网 aTgHTML5中文学习网 - HTML5先行者学习网
function drawScreen() { aTgHTML5中文学习网 - HTML5先行者学习网
context.strokeStyle = "black"; aTgHTML5中文学习网 - HTML5先行者学习网
context.lineWidth = 10; aTgHTML5中文学习网 - HTML5先行者学习网
context.lineCap = 'square'; aTgHTML5中文学习网 - HTML5先行者学习网
context.beginPath(); aTgHTML5中文学习网 - HTML5先行者学习网
context.moveTo(20, 0); aTgHTML5中文学习网 - HTML5先行者学习网
context.lineTo(100, 0); aTgHTML5中文学习网 - HTML5先行者学习网
context.stroke(); aTgHTML5中文学习网 - HTML5先行者学习网
context.closePath(); aTgHTML5中文学习网 - HTML5先行者学习网
} aTgHTML5中文学习网 - HTML5先行者学习网
aTgHTML5中文学习网 - HTML5先行者学习网在上面的例子中,我们描画了一条水平的、宽度为10个像素的线段;与此同时,我们还设定了lineCap与strokeStyle属性。以下是一些常用的属性列表:
aTgHTML5中文学习网 - HTML5先行者学习网aTgHTML5中文学习网 - HTML5先行者学习网lineCap
aTgHTML5中文学习网 - HTML5先行者学习网lineCap定义了在Canvas中线段两头的样式,可设置为以下三个值中的一个:
aTgHTML5中文学习网 - HTML5先行者学习网aTgHTML5中文学习网 - HTML5先行者学习网butt。默认值;在线段的两头添加平直边缘。
aTgHTML5中文学习网 - HTML5先行者学习网round。在线段的两头各添加一个半圆形线帽。线帽直径等于线段的宽度。
aTgHTML5中文学习网 - HTML5先行者学习网square。在线段的两头添加正方形线帽。线帽边长等于线段的宽度。
aTgHTML5中文学习网 - HTML5先行者学习网lineJoin
aTgHTML5中文学习网 - HTML5先行者学习网lineJoin定义了两条线段相交处的弯角样式。以下为三个可选的值:
aTgHTML5中文学习网 - HTML5先行者学习网aTgHTML5中文学习网 - HTML5先行者学习网miter。默认值;创建一个尖角。可以通过设置miterLimit属性来对尖角长度进行限制 — miterLimit为尖角长度和线条宽度之比的最大值,默认为10。
aTgHTML5中文学习网 - HTML5先行者学习网bevel。创建一个斜角。
aTgHTML5中文学习网 - HTML5先行者学习网round。创建一个圆角。
aTgHTML5中文学习网 - HTML5先行者学习网lineWidth
aTgHTML5中文学习网 - HTML5先行者学习网lineWidth定义了线条的粗细,默认为1.0。
aTgHTML5中文学习网 - HTML5先行者学习网aTgHTML5中文学习网 - HTML5先行者学习网strokeStyle
aTgHTML5中文学习网 - HTML5先行者学习网strokeStyle定义了用于渲染线条的颜色等样式。
aTgHTML5中文学习网 - HTML5先行者学习网aTgHTML5中文学习网 - HTML5先行者学习网译注:当lineJoin设定为miter,但是尖角长度超过了miterLimit的限制时,Canvas将显示“bevel”弯角效果。
aTgHTML5中文学习网 - HTML5先行者学习网