如何使用 FabricJS 設定文字框的水平縮放因子?


在本教程中,我們將學習如何使用 FabricJS 設定文字框的水平縮放因子。我們可以自定義、拉伸或移動文字框中編寫的文字。為了建立文字框,我們必須建立一個 fabric.Textbox 類的例項並將其新增到畫布中。就像我們可以在畫布中指定文字框物件的 position、顏色、不透明度和尺寸一樣,我們還可以設定文字框物件的水平縮放因子。這可以透過使用 scaleX 屬性來完成。

語法

new fabric.Textbox(text: String, { scaleX : Number }: Object)

引數

  • text − 此引數接受一個字串,即我們希望在文字框內顯示的文字字串。

  • options (可選) − 此引數是一個物件,它為我們的文字框提供了額外的自定義。使用此引數,可以更改與物件相關的屬性,例如顏色、游標、筆觸寬度以及許多其他屬性,其中scaleX 是一個屬性。

選項鍵

  • scaleX  此屬性接受一個數字值。分配的值決定了水平物件縮放因子。其預設值為 1。

示例 1

未使用 scaleX 時的預設外觀

讓我們看一個程式碼示例,該示例顯示了當未使用 scaleX 屬性時文字框物件的外觀。預設情況下,文字框物件的水平縮放因子為 1。scaleX 確定沿 X 軸調整物件大小的變換。

<!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>Default appearance when scaleX is not used</h2> <p>You can see that there is no resizing along the x-axis</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 textbox object var textbox = new fabric.Textbox("Believe you can and you're halfway there.", { backgroundColor: "#fffff0", width: 400, left: 50, top: 70, fill: "violet", strokeWidth: 2, stroke: "blue", textAlign: "center", }); // Add it to the canvas canvas.add(textbox); </script> </body> </html>

示例 2

scaleX 屬性作為鍵傳遞

在此示例中,我們將 scaleX 屬性作為鍵傳遞,其值為 2。這意味著文字框物件在水平方向上的縮放因子加倍。

<!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 scaleX property as key</h2> <p>You can see that the objects horizontal width has been doubled</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 textbox object var textbox = new fabric.Textbox("Believe you can and you're halfway there.", { backgroundColor: "#fffff0", width: 400, left: 50, top: 70, fill: "violet", strokeWidth: 2, stroke: "blue", textAlign: "center", scaleX: 2, }); // Add it to the canvas canvas.add(textbox); </script> </body> </html>

更新於: 2022年8月2日

224 次瀏覽

啟動你的 職業生涯

透過完成課程獲得認證

開始學習
廣告