视频1 视频21 视频41 视频61 视频文章1 视频文章21 视频文章41 视频文章61 推荐1 推荐3 推荐5 推荐7 推荐9 推荐11 推荐13 推荐15 推荐17 推荐19 推荐21 推荐23 推荐25 推荐27 推荐29 推荐31 推荐33 推荐35 推荐37 推荐39 推荐41 推荐43 推荐45 推荐47 推荐49 关键词1 关键词101 关键词201 关键词301 关键词401 关键词501 关键词601 关键词701 关键词801 关键词901 关键词1001 关键词1101 关键词1201 关键词1301 关键词1401 关键词1501 关键词1601 关键词1701 关键词1801 关键词1901 视频扩展1 视频扩展6 视频扩展11 视频扩展16 文章1 文章201 文章401 文章601 文章801 文章1001 资讯1 资讯501 资讯1001 资讯1501 标签1 标签501 标签1001 关键词1 关键词501 关键词1001 关键词1501 专题2001
html51px问题以及绘制坐标系网格的方法
2020-11-27 15:28:15 责编:小采
文档
在canvas中,要画出1px的线条,默认情况下是不行的

context.beginPath();
 context.moveTo( 100, 100 );
 context.lineTo( 400, 100 );
 context.closePath();
 context.stroke();
 context.beginPath();
 context.strokeStyle = 'red';
 context.moveTo( 100.5, 200.5 );
 context.lineTo( 400.5, 200.5 );
 context.closePath();
 context.stroke();

上述代码中,context是canvas的上下文,在这段代码中,我画了2条线,上面那条线并不是1px,下面的那条线才是1px

上面你可能还看不清楚,那条黑线到底是不是1px,你可以把他们放到画图软件或者photoshop中,放大,然后打开坐标,就能看到如下效果:

很明显,这条黑线,占据的是2行,就是2px大小,而红线占据了一行,才是真正的1px的线段,也就是说,在canvas中,你如果需要绘制一条1px的线段,那么坐标后面要加上0.5,那么,接下来,我们就来绘制一个坐标系,x,y方向的坐标系刻度为10px.

drawGrid('#09f', 10, 10);
 function drawGrid(color, stepx, stepy) {
 context.save()

 context.strokeStyle = color;
 context.lineWidth = 0.5;
 context.clearRect(0, 0, context.canvas.width, context.canvas.height);

 for (var i = stepx + 0.5; i < context.canvas.width; i += stepx) {
 context.beginPath();
 context.moveTo(i, 0);
 context.lineTo(i, context.canvas.height);
 context.stroke();
 }

 for (var i = stepy + 0.5; i < context.canvas.height; i += stepy) {
 context.beginPath();
 context.moveTo(0, i);
 context.lineTo(context.canvas.width, i);
 context.stroke();
 }

 context.restore();
 }

下载本文
显示全文
专题