线型Line styles
线型包括如下属性。
lineWidth = value
lineCap = type
lineJoin = type
miterLimit = value
通过这些属性来设置线的样式。下面将结合实例来讲解一下各属性的应用及应用后的效果。
lineWidth属性
该属性设置当前绘线的粗细,属性值必须为正数。默认值是1.0。线宽是指给定路径的中心到两边的粗细。换句话说就是在路径的两边各绘制线宽的一半。因为画布的坐标并不和像素直接对应,当需要获得精确的水平或垂直线时要特别注意。
【例17.10】在下面的例子中,用递增的宽度绘制了10条直线,最左边的线宽1.0单位。
本例实现的主要代码如下。
for (var i = 0; i < 10; i++){
context.lineWidth = 1+i;
context.beginPath();
context.strokeStyle = '#c00';
context.moveTo(5+i*14,5);
context.lineTo(5+i*14,140);
context.stroke();
设置不同值的lineWidth效果
lineCap属性
该属性决定了线段端点显示的样子。它可以为下面的3种值之一:butt、round和square,默认是butt。
【例17.11】在下面的例子中,绘制了3条直线,分别赋予不同的lineCap值。还有两条辅助线,为了可以看清楚它们之间的区别,赋予lineCap值的3条线的起点终点都落在辅助线上。
最左边的线用了默认的butt。可以注意到它是与辅助线齐平的。中间的是round的效果,端点处加上了半径为一半线宽的半圆。右边的是square的效果,端点处加上了等宽且高度为一半线宽的方块。其实现的代码如下。
lineJoin属性
该属性值决定了图形中两线段连接处所显示的样子,具体有3种取值:round、bevel和miter,默认是miter。
【例17.12】在下面的实例中同样绘制了3条折线,分别设置不同的lineJoin值。最上面一条是round的效果,边角处被磨圆了,圆的半径等于线宽。中间和最下面一条分别是bevel和miter的效果。这里需要注意的是,当值是miter的时候,线段会在连接处外侧延伸直至交于一点,延伸效果受到miterLimit属性的制约。
lineCap属性的赋值的3种效果
从效果图可以看出应用miter(最下面的一条)的效果,线段的外侧边缘会延伸交汇于一点上。线段直接夹角比较大的,交点不会太远,但当夹角减少时,交点距离会呈指数级增大。miterLimit属性就是用来设定外延交点与连接点的最大距离,如果交点距离大于此值,连接效果会变成bevel。
https://www.bilibili.com/video/BV1Gv4y1Q7px/?spm_id_from=333.999.0.0&vd_source=a7816e3b2a3a67ac39dc87f6bf92421chttps://www.bilibili.com/video/BV1Gv4y1Q7px/?spm_id_from=333.999.0.0&vd_source=a7816e3b2a3a67ac39dc87f6bf92421c