HTML5中canvas如何画虚线

虚线也可以看成是一段段的实线组成的,而实线是利用context.moveTo(x,y);context.lineTo(x2,y2);context.stroke();

那么我们就可以利用context的基本方法来完成虚线的实现原理,如下:

var context = document.getElementById('canvas').getContext('2d');//求斜边长度function getBeveling(x,y){return Math.sqrt(Math.pow(x,2)+Math.pow(y,2));}function drawDashLine(context,x1,y1,x2,y2,dashLen){dashLen = dashLen === undefined ? 5 : dashLen;//得到斜边的总长度var beveling = getBeveling(x2-x1,y2-y1);//计算有多少个线段var num = Math.floor(beveling/dashLen);for(var i = 0 ; i < num; i++){context[i%2 == 0 ? 'moveTo' : 'lineTo'](x1+(x2-x1)/num*i,y1+(y2-y1)/num*i);}context.stroke();}drawDashLine(context,50,50,300,180,5);展示效果如下:

,成功不是将来才有的,而是从决定去做的那一刻起,持续累积而成。

HTML5中canvas如何画虚线

相关文章:

你感兴趣的文章:

标签云: