如何使用FabricJS用Polygon类制作一个星形
我们可以通过创建一个fabric.Polygon的实例来创建一个Polygon对象。一个多边形对象可以被描述为由一组连接的直线段组成的任何封闭形状。由于它是FabricJS的基本元素之一,我们也可以通过应用角度、不透明度等属性轻松地定制它。
语法
new fabric.Polygon( points: Array, options: Object )
参数
- points – 这个参数接受一个数组,表示构成多边形对象的点的数组。
-
options (可选) – 这个参数是一个Object,为我们的对象提供额外的定制。使用这个参数可以改变多边形对象的原点、笔触宽度和许多其他相关的属性。
例1:多边形对象的默认外观
让我们看看如何绘制任何一般的多边形对象的代码例子。我们需要指定一个点的数组,每个点都是一个有 “x “和 “y “的对象。指定点的数组是至关重要的,没有它,我们的多边形对象就不会被渲染到画布上。
<!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>Default appearance of polygon object</h2>
<p>You can see that a polygon 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);
// Initiate a polygon instance
var polygon = new fabric.Polygon(
[
{ x: 500, y: 20 },
{ x: 550, y: 60 },
{ x: 550, y: 200 },
{ x: 350, y: 200 },
{ x: 350, y: 60 },
{ x: 500, y: 20 },
],
{
fill: "black",
stroke: "blue",
strokeWidth: 2,
}
);
// Adding it to the canvas
canvas.add(polygon);
</script>
</body>
</html>
例2:使用多边形绘制星星
让我们看一个代码例子来了解我们如何用Polygon画一个星星。一颗星或五角星由10个等腰三角形组成。这些等腰三角形中不等边的长度有一个1.618的黄金比例。我们可以以这种方式选择坐标,使形状形成一个星形,如下所示。
<!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 Star using Polygon</h2>
<p>You can see that a star 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 a points array
var points = [
{ x: 349.9, y: 75, },
{ x: 379, y: 160.9,},
{ x: 469, y: 160.9,},
{ x: 397, y: 214.9,},
{ x: 423, y: 300.9,},
{ x: 350, y: 249.9,},
{ x: 276.9, y: 301,},
{ x: 303, y: 215,},
{ x: 231, y: 161,},
{ x: 321, y: 161,},
];
// Initiating a polygon object
var polygon = new fabric.Polygon(points, {
left: 100,
top: 10,
fill: "#D81B60",
strokeWidth: 4,
stroke: "green",
cornerColor: "blue",
});
// Adding it to the canvas
canvas.add(polygon);
</script>
</body>
</html>
结论
在本教程中,我们用两个简单的例子来演示如何使用FabricJS用Polygon制作一个星星符号。