FabricJS – 如何將影像物件縮放至給定寬度?
在本教程中,我們將學習如何使用 FabricJS 將影像物件縮放至給定寬度。我們可以透過建立fabric.Image的例項來建立影像物件。由於它是 FabricJS 的基本元素之一,我們也可以透過應用角度、不透明度等屬性輕鬆自定義它。為了將影像物件縮放至給定寬度,我們使用scaleToWidth方法。
語法
scaleToWidth(value: Number, absolute: Boolean): fabric.Object
引數
value − 此引數接受一個數字,用於確定影像物件的新寬度值。
absolute − 此引數接受一個布林值,用於確定是否忽略視口。
影像物件的預設外觀
示例
讓我們來看一個程式碼示例,看看當不使用scaleToWidth方法時,我們的影像物件是什麼樣的。在這種情況下,我們的影像物件不會在水平或垂直方向上縮放。
<!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 of the Image object</h2> <p> You can see that the object has not been scaled in horizontal or vertical direction </p> <canvas id="canvas"></canvas> <img src="https://tutorialspoint.tw/images/logo.png" id="img1" style="display: none" /> <script> // Initiate a canvas instance var canvas = new fabric.Canvas("canvas"); canvas.setWidth(document.body.scrollWidth); canvas.setHeight(250); // Initiating the image element var imageElement = document.getElementById("img1"); // Initiate an Image object var image = new fabric.Image(imageElement, { top: 50, left: 110, }); // Add it to the canvas canvas.add(image); </script> </body> </html>
使用自定義值傳遞scaleToWidth方法
示例
在這個示例中,我們將看到如何將值賦給scaleToWidth方法,將我們的影像物件縮放至給定寬度。由於我們傳遞的值為 200,這將是影像物件的新寬度。
<!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 the scaleToWidth method with a custom value</h2> <p>You can see that the new width of our image object is 200</p> <canvas id="canvas"></canvas> <img src="https://tutorialspoint.tw/images/logo.png" id="img1" style="display: none" /> <script> // Initiate a canvas instance var canvas = new fabric.Canvas("canvas"); canvas.setWidth(document.body.scrollWidth); canvas.setHeight(250); // Initiating the image element var imageElement = document.getElementById("img1"); // Initiate an Image object var image = new fabric.Image(imageElement, { top: 50, left: 110, }); // Using the scaleToWidth method image.scaleToWidth(200, false); // Add it to the canvas canvas.add(image); </script> </body> </html>
廣告
資料結構
網路
關係資料庫管理系統 (RDBMS)
作業系統
Java
iOS
HTML
CSS
Android
Python
C語言程式設計
C++
C#
MongoDB
MySQL
Javascript
PHP