如何使用 FabricJS 获取 Line 对象的坐标?
在本教程中,我们将展示如何使用 FabricJS 获取线的坐标。 Line 元素是 FabricJS 中提供的基本元素之一。它用于创建直线。由于线元素在几何上是一维的并且不包含内部,因此它们永远不会被填充。我们可以通过创建 fabric.Line 的实例来创建线条对象,指定线条的 x 和 y 坐标并将其添加到画布中。为了获取 Line 对象的坐标,我们使用 getCoords 方法。
语法
getCoords(): Array
使用 getCoords 方法
示例
让我们看一个代码示例,以查看 getCoords 方法执行时记录的输出用过的。 getCoords 方法以数组格式返回 Line 的左上角、右上角、右下角和左下角坐标。
<!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>Using getCoords method</h2> <p>You can open console from dev tools and see the logged output</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 Line object var line = new fabric.Line([50, 100, 310, 100], { stroke: "blue", strokeWidth: 10, }); // Add it to the canvas canvas.add(line); // Using getCoords method console.log("The coordinates are: ", line.getCoords()); </script> </body> </html>
使用 getCoords 方法绘制斜线
示例
在此示例中,我们使用了 getCoords 方法获取具有不同起始和结束坐标的 Line 实例的坐标。我们可以看到记录的输出是:(100, 40)、(220, 40)、(220,120)、(100,120),分别是该行的左上角、右上角、右下角和左下角坐标.
<!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>Using getCoords method for a slant line</h2> <p>You can open console from dev tools and see the logged output</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 Line object var line = new fabric.Line([200, 100, 100, 40], { stroke: "blue", strokeWidth: 20 }); // Add it to the canvas canvas.add(line); // Using getCoords method console.log("The coordinates are: ", line.getCoords()); </script> </body> </html>
以上就是如何使用 FabricJS 获取 Line 对象的坐标?的详细内容,更多请关注双恒网络其它相关文章!
声明:本站所有文章,如无特殊说明或标注,均为本站原创发布。任何个人或组织,在未征得本站同意时,禁止复制、盗用、采集、发布本站内容到任何网站、书籍等各类媒体平台。如若本站内容侵犯了原著者的合法权益,可联系我们进行处理。