如何使用 FabricJS 创建带有背景图像的画布?

fabricjsjavascripthtml5 canvas

在本文中,我们将使用 FabricJS 创建带有背景图像的画布。FabricJS 中有两种方法可以更改画布的背景图像。

  • 第一种方法是使用 Canvas 类本身并在该类的第二个参数中传递 backgroundImage

  • 第二种方法是使用 setBackgroundColor 方法。让我们通过一个例子来了解它们中的每一个。

方法 1:使用 Canvas 类

在第一种方法中,我们将通过在类的第二个参数中传递 backgroundImage 来使用 Canvas 类本身。

语法

new fabric.Canvas(element: HTMLElement|String, {backgroundImage: fabric.Image}: Object)

参数

  • element − 此参数是 <canvas> 元素本身,可以使用 document.getElementById()<canvas> 元素本身的 id 派生。 FabricJS 画布将在此元素上初始化。

  • 选项(可选) − 此参数是一个对象,它为我们的画布提供额外的自定义,backgroundImage 就是其中之一,它将帮助我们自定义背景图像。backgroundImage 将 fabric.Image 作为指定画布背景图像的值。

示例 1

查看以下示例,该示例演示了如何使用 FabricJS 创建带有背景图像的画布。由于 FabricJS 在 Canvas API 之上工作,我们将使用 <canvas> 标记创建一个 HTML 元素并为其指定一个 id。此外,我们将该 id 传递给 FabricJS API,以便它可以在 <canvas> 上初始化 FabricJS Canvas 实例标签,在第二个参数中,我们将传递一个对象,其键为 backgroundImage,值是图像的 URL。

<!DOCTYPE html>
<html>
<head>
   <!-- 添加 Fabric JS 库-->
   <script src="https://cdnjs.cloudflare.com/ajax/libs/fabric.js/510/fabric.min.js"></script>
</head>
<body>
   <h2> 在 Fabric.js 中创建带有背景图像的画布 </h2>
   <canvas id="canvas"> </canvas>
   <script>
      //初始化一个画布实例
      var canvas = new fabric.Canvas("canvas", {
         backgroundImage: "https://www.tutorialspoint.com/tools/images/logo.png",
      });
      canvas.setWidth(document.body.scrollWidth);
      canvas.setHeight(250);
   </script>
</body>
</html>

方法 2:使用 setBackgroundImage 方法

创建画布后,我们还可以使用 Canvas 类中提供的 setBackgroundImage 方法。让我们仔细看看如何实现这一点。

语法

canvas.setBackgroundImage(image: fabric.Image | String, callback: function, options: Object)

参数

  • image − 此参数接受 fabric.Image 或字符串,该字符串引用我们要设置背景的图像的 url。

  • callback −此参数采用回调函数,该函数在加载图像并将其设置为背景时调用。

  • 选项(可选): − 此参数是一个对象,我们可以在其中指定背景图像的选项。我们可以更改不透明度,放大或缩小图像等。

示例 2

首先,我们将图像 URL 分配给一个变量,并将其用作第一个参数。在第二个参数中,我们将使用 renderAll() 方法在设置背景图像后绑定画布,如以下代码所示 −

<!DOCTYPE html>
<html>
<head>
   <!-- 添加 Fabric JS 库-->
   <script src="https://cdnjs.cloudflare.com/ajax/libs/fabric.js/510/fabric.min.js"></script>
</head>
<body>
   <h2> 在 Fabric.js 中创建带有背景图像的画布 </h2>
   <p> 这里我们使用了 setBackgroundImage 方法。</p>
   <canvas id="canvas"> </canvas>
   <script>
      // 启动一个canvas实例    var canvas = new Fabric.Canvas("canvas");
      // 图片网址
      var imageURL = "https://www.tutorialspoint.com/tools/images/logo.png";
      canvas.setBackgroundImage(imageURL, canvas.renderAll.bind(canvas), {
         backgroundImageOpacity: 1,
         originX: "left",
         originY: "top",
         top: 90,
         left: 70,
         scaleX: 1.1,
         scaleY: 1.1,
      });
      canvas.setWidth(document.body.scrollWidth);
      canvas.setHeight(250);
   </script>
</body>
</html>

相关文章