如何使用 FabricJS 設定矩形 Y 軸的傾斜角度?


在本教程中,我們將學習如何使用 FabricJS 設定矩形 Y 軸的傾斜角度。矩形是 FabricJS 提供的各種形狀之一。為了建立一個矩形,我們將必須建立一個 `fabric.Rect` 類的例項並將其新增到畫布。

我們的矩形物件可以透過多種方式進行自定義,例如更改其尺寸、新增背景顏色或更改 Y 軸的傾斜角度。我們可以使用 `skewY` 屬性來實現這一點。

語法

new fabric.Rect({ skewY : Number }: Object)

引數

  • **選項 (可選)** - 此引數是一個物件,它為我們的矩形提供額外的自定義選項。使用此引數,可以更改與物件相關的許多屬性,例如顏色、游標、筆劃寬度以及 `skewY` 屬性。

選項鍵

  • **`skewY`** - 此屬性接受一個**數字**,該數字確定物件的 Y 軸傾斜角度。

示例 1

未應用 skewY 屬性時

讓我們來看一個程式碼示例,瞭解當未應用 `skewY` 屬性時我們的矩形物件是如何顯示的。在這種情況下,我們的矩形物件將不會有任何角度的傾斜。

<!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>When the skewY property is not applied</h2>
   <p>You can see there is no skew by any angle on the rectangle by default</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 rectangle object
      var rect = new fabric.Rect({
         left: 105,
         top: 70,
         width: 170,
         height: 70,
         fill: "#8f9779",
         stroke: "#8fbc8f",
         strokeWidth: 9,
      });

      // Add it to the canvas
      canvas.add(rect);
   </script>
</body>
</html>

示例 2

將 skewY 作為鍵併為其賦值自定義值。

在這個例子中,我們將看到如何為 `skewY` 屬性賦值一個數值。傳遞的值將決定沿 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>Passing skewY as key and assigning a custom value to it</h2>
   <p>You can see the rectangle has been skewed by 30 degrees along the Yaxis</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 rectangle object
      var rect = new fabric.Rect({
         left: 105,
         top: 70,
         width: 170,
         height: 70,
         fill: "#8f9779",
         stroke: "#8fbc8f",
         strokeWidth: 9,
         skewY: 30,
      });

      // Add it to the canvas
      canvas.add(rect);
   </script>
</body>
</html>

更新於:2022年6月30日

170 次瀏覽

開啟你的職業生涯

完成課程獲得認證

開始學習
廣告