如何使用 FabricJS 创建带有边框颜色的椭圆形?
在本教程中,我们将学习如何使用 FabricJS 创建带有边框颜色的椭圆形。椭圆形是 FabricJS 提供的各种形状之一。为了创建椭圆形,我们将创建一个fabric.Ellipse类的实例并将其添加到画布中。由于 FabricJS 非常灵活,我们可以根据需要自定义椭圆对象。FabricJS 提供的一个属性是borderColor,它允许我们在对象处于活动状态时操作边框的颜色。
语法
new fabric.Ellipse({ borderColor: String }: Object)
参数
options (可选) − 此参数是一个对象,它为我们的椭圆提供了额外的自定义选项。使用此参数可以更改与对象相关的颜色、光标、笔划宽度以及许多其他属性,其中borderColor也是一个属性。
选项键
borderColor − 此属性接受一个字符串,用于确定对象被选中时边框的颜色。其默认值为rgb(178,204,255)。
示例 1
使用字符串值传递 borderColor 键
让我们来看一个如何为borderColor属性赋值的例子。我们将值“blue”赋给 borderColor 键,这有助于在选中椭圆对象时创建蓝色边框。
<!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>How to create an Ellipse with a border color using FabricJS?</h2> <p>Select the object to see the "blue" border color.</p> <canvas id="canvas"></canvas> <script> // Initiate a canvas instance var canvas = new fabric.Canvas("canvas"); // Initiate an Ellipse instance var ellipse = new fabric.Ellipse({ left: 215, top: 100, rx: 90, ry: 50, fill: "red", borderColor: "blue", }); // Adding it to the canvas canvas.add(ellipse); canvas.setWidth(document.body.scrollWidth); canvas.setHeight(250); </script> </body> </html>
示例 2
向borderColor键传递 rgba 值
除了传递简单的颜色名称作为字符串外,我们还可以使用RGBA值,其组件指定红色、绿色、蓝色和 Alpha 的数量,其中 Alpha 表示不透明度。在这个例子中,我们使用了rgb(128,0,128),这是紫色对应的 rgb 值。
<!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>How to create an Ellipse with a border color using FabricJS?</h2> <p>Select the object to see the "purple" border color.</p> <canvas id="canvas"></canvas> <script> // Initiate a canvas instance var canvas = new fabric.Canvas("canvas"); // Initiate an Ellipse instance var ellipse = new fabric.Ellipse({ left: 215, top: 100, rx: 90, ry: 50, fill: "red", borderColor: "rgb(128,0,128)", }); // Adding it to the canvas canvas.add(ellipse); canvas.setWidth(document.body.scrollWidth); canvas.setHeight(250); </script> </body> </html>
广告