我想绘制如图所示的网格,但我完全不知道从哪里开始。
我应该使用 SVG 还是应该使用带有 HTML5 的 Canvas 以及如何在上面绘图?
我希望此网格在其上绘制矩形、圆形或其他图表,我将计算该图表的面积,就像计算正方形的面积一样。
原文由 Sandeep Kumar 发布,翻译遵循 CC BY-SA 4.0 许可协议
我想绘制如图所示的网格,但我完全不知道从哪里开始。
我应该使用 SVG 还是应该使用带有 HTML5 的 Canvas 以及如何在上面绘图?
我希望此网格在其上绘制矩形、圆形或其他图表,我将计算该图表的面积,就像计算正方形的面积一样。
原文由 Sandeep Kumar 发布,翻译遵循 CC BY-SA 4.0 许可协议
我在 SO 上使用 canvas
发布我的代码,但我也在 JSFiddle here 上创建一个工作示例。
<!DOCTYPE html>
<html>
<head>
<title>StackOverflow test bed</title>
<script type="text/javascript">
function drawGrid() {
var cnv = document.getElementById("cnv");
var gridOptions = {
minorLines: {
separation: 5,
color: '#00FF00'
},
majorLines: {
separation: 30,
color: '#FF0000'
}
};
drawGridLines(cnv, gridOptions.minorLines);
drawGridLines(cnv, gridOptions.majorLines);
return;
}
function drawGridLines(cnv, lineOptions) {
var iWidth = cnv.width;
var iHeight = cnv.height;
var ctx = cnv.getContext('2d');
ctx.strokeStyle = lineOptions.color;
ctx.strokeWidth = 1;
ctx.beginPath();
var iCount = null;
var i = null;
var x = null;
var y = null;
iCount = Math.floor(iWidth / lineOptions.separation);
for (i = 1; i <= iCount; i++) {
x = (i * lineOptions.separation);
ctx.moveTo(x, 0);
ctx.lineTo(x, iHeight);
ctx.stroke();
}
iCount = Math.floor(iHeight / lineOptions.separation);
for (i = 1; i <= iCount; i++) {
y = (i * lineOptions.separation);
ctx.moveTo(0, y);
ctx.lineTo(iWidth, y);
ctx.stroke();
}
ctx.closePath();
return;
}
</script>
</head>
<body onload="drawGrid()">
<canvas id="cnv" width="500" height="500"></canvas>
</body>
</html>
使用 canvas
方法,您可以通过更改 separation
参数使网格大小动态变化。
但是,如果您的网格大小将是 静态 的,我觉得您 可能 不需要 绘制 网格。只是为了向用户显示网格,您可以使用 CSS 重复背景图像,如此处的小提琴 所示。这对页面性能也有好处。
原文由 Tanzeel Kazi 发布,翻译遵循 CC BY-SA 3.0 许可协议
2 回答1.5k 阅读✓ 已解决
2 回答897 阅读✓ 已解决
1 回答1.1k 阅读✓ 已解决
1 回答908 阅读✓ 已解决
2 回答789 阅读
1 回答780 阅读✓ 已解决
2 回答1.1k 阅读
SVG 可以使用模式很好地做到这一点:
我将
width
和height
设置为100%
,因此您可以在使用时定义实际宽度和高度,或者用于内联 SVG:或
<img>
元素:结果是:
(抱歉,如果图像没有显示——似乎没有像 Imgur 这样可靠地托管 SVG 的东西。)
结果是
请注意,对于此特定网格,如果您希望网格以粗笔画开始和结束,则必须使用
n x 80 + 1
形式的宽度和高度(其中n
是任何整数)。