Fabric.js – 如何用Polygon类绘制六边形网格
我们可以通过创建一个 fabric.Polygon 的实例来创建一个 Polygon 对象。一个多边形对象可以被描述为由一组连接的直线段组成的任何封闭形状。由于它是FabricJS的基本元素之一,我们也可以通过应用角度、不透明度等属性轻松地定制它。
语法
new fabric.Polygon( points: Array, options: Object )
参数
- points – 这个参数接受一个数组,表示构成多边形对象的点的数组。
-
options(option) – 这个参数是一个Object,为我们的对象提供额外的定制。使用这个参数可以改变多边形对象的原点、笔触宽度和许多其他相关的属性。
例1:使用多边形绘制六边形
让我们看一个代码例子,看看我们如何用多边形画一个_六边形。我们可以画很多类型的六边形,然而,在这个例子中我们将画一个正六边形。我们知道,一个正六边形有六个相等的边。
<!DOCTYPE html>
<html>
<head>
<!-- Adding the Fabric JS Library-->
<script src="https://cdnjs.cloudflare.com/ajax/libs/fabric.js/510/fabric.min.js"></script>
</head>
<body>
<h2>Drawing a Hexagon using Polygon</h2>
<p>You can see a hexagon object has been added to the canvas</p>
<canvas id="canvas"></canvas>
<script>
// Initiate a canvas instance
var canvas = new fabric.Canvas("canvas");
canvas.setWidth(document.body.scrollWidth);
canvas.setHeight(250);
// Initiating the angle of the hexagon
const a = (2 * Math.PI) / 6;
// Initiating the radius of the circle
const r = 50;
// Initiate a polygon object
var hexagon = new fabric.Polygon(
[
{ x: 50, y: 0 },
{ x: 25, y: 43.30},
{ x: -25, y: 43.301 },
{ x: -50, y: 0},
{ x: -25, y: -43.301},
{ x: 25, y: -43.301 },
],
{
stroke: "red",
left: 140,
top: 10,
strokeWidth: 2,
strokeLineJoin: "bevil",
}
);
// Adding it to the canvas
canvas.add(hexagon);
</script>
</body>
</html>
例2:使用Polygon绘制六角形网格
让我们看一个代码例子,看看我们如何创建一个六边形的网格。我们可以简单地启动一个叫做drawHexagon (m,n)的函数,其中(m,n)是一个六边形的中心点。这个函数只要被调用就会画出六边形。我们还启动了drawGrid(width, height)函数,通过计算连续的六边形的下一个中心点的位置来绘制连续的六边形。
<!DOCTYPE html>
<html>
<head>
<!-- Adding the Fabric JS Library-->
<script src="https://cdnjs.cloudflare.com/ajax/libs/fabric.js/510/fabric.min.js"></script>
</head>
<body>
<h2>Drawing a Hexagonal grid using Polygon</h2>
<p>You can see that a hexagonal grid has been drawn</p>
<canvas id="canvas"></canvas>
<script>
// Initiate a canvas instance
var canvas = new fabric.Canvas("canvas");
canvas.setWidth(document.body.scrollWidth);
canvas.setHeight(250);
// Initiate a polygon object
function drawHexagon(left, top) {
var hexagon = new fabric.Polygon(
[
{ x: 50, y: 0 },
{ x: 25, y: 43.30},
{ x: -25, y: 43.301 },
{ x: -50, y: 0},
{ x: -25, y: -43.301},
{ x: 25, y: -43.301 },
],
{
stroke: "#EEC33D",
fill: "#BB900C",
strokeWidth: 5,
left: left,
top: top
}
);
// Adding it to the canvas
canvas.add(hexagon);
}
// Initiating the drawGrid function
function drawGrid() {
for (let y = 1; y < 4; y++) {
drawHexagon(80*y,45*y)
}
for (let y = 1; y < 4; y++) {
drawHexagon(80*y+160,45*y)
}
for (let y = 1; y < 4; y++) {
drawHexagon(80*y+320,45*y)
}
}
// Calling drawGrid function
drawGrid();
</script>
</body>
</html>
结论
在本教程中,我们用两个简单的例子来演示如何用FabricJS的Polygon类来绘制一个六边形网格。