Fabric.js 多边形borderScaleFactor属性
在本文中,我们将看到如何通过使用 FabricJS 来启用画布多边形的边框缩放。画布多边形意味着多边形是可移动的,并且可以根据需要进行拉伸。此外,当涉及到初始描边颜色、高度、宽度、填充颜色或描边宽度时,可以对多边形进行自定义设置。
为了实现这一点,我们将使用一个名为 FabricJS 的JavaScript库。在导入该库之后,我们将在标签中创建一个包含多边形的画布块。之后,我们将初始化由 FabricJS 提供的Canvas和polygon实例,并使用 borderScaleFactor 属性来启用画布三角形的边框缩放,并将多边形渲染到Canvas上,如下所示。
语法:
fabric.Polygon([
{ x: pixel, y: pixel },
{ x: pixel, y: pixel },
{ x: pixel, y: pixel},
{ x: pixel, y: pixel},
{ x: pixel, y: pixel }],
{
borderScaleFactor: number
});
参数: 此属性接受一个上述所述并描述如下的单个参数:
- borderScaleFactor: 此参数定义是否启用或禁用边框缩放以及缩放的程度。
注意: 尺寸像素必须创建一个多边形。
以下示例说明了Fabric.JS的JavaScript中的borderScaleFactor填充属性:
示例1: 在此示例中,我们将设置borderScaleFactor的值为5。
<!DOCTYPE html>
<html>
<head>
<!-- Loading the FabricJS library -->
<script src=
"https://cdnjs.cloudflare.com/ajax/libs/fabric.js/3.6.2/fabric.min.js">
</script>
</head>
<body>
<div style="text-align: center;width: 600px;">
<h1 style="color: green;">
GeeksforGeeks
</h1>
<b>
Fabric.js | Polygon fill Property
</b>
</div>
<canvas id="canvas"
width="600"
height="200"
style="border:1px solid #000000;">
</canvas>
<script>
// Initiate a Canvas instance
var canvas = new fabric.Canvas("canvas");
// Initiate a polygon instance
var polygon = new fabric.Polygon([
{ x: 295, y: 10 },
{ x: 235, y: 198 },
{ x: 385, y: 78},
{ x: 205, y: 78},
{ x: 355, y: 198 }], {
fill: 'purple',
borderScaleFactor: 5
});
// Render the polygon in canvas
canvas.add(polygon);
</script>
</body>
</html>
输出:
示例2: 在这个示例中,我们将设置borderScaleFactor值为1。
<!DOCTYPE html>
<html>
<head>
<!-- Loading the FabricJS library -->
<script src=
"https://cdnjs.cloudflare.com/ajax/libs/fabric.js/3.6.2/fabric.min.js">
</script>
</head>
<body>
<div style="text-align: center;width: 600px;">
<h1 style="color: green;">
GeeksforGeeks
</h1>
<b>
Fabric.js | Polygon borderScaleFactor Property
</b>
</div>
<canvas id="canvas"
width="600"
height="200"
style="border:1px solid #000000;">
</canvas>
<script>
// Initiate a Canvas instance
var canvas = new fabric.Canvas("canvas");
// Initiate a polygon instance
var polygon = new fabric.Polygon([
{ x: 295, y: 10 },
{ x: 235, y: 198 },
{ x: 385, y: 78},
{ x: 205, y: 78},
{ x: 355, y: 198 }], {
fill: 'yellow',
borderScaleFactor: 1
});
// Render the polygon in canvas
canvas.add(polygon);
</script>
</body>
</html>
输出: