如何在 FabricJS 中獲取 IText 中單詞的右邊界?
在本教程中,我們將學習如何在 FabricJS 中獲取 IText 中單詞的右邊界。IText 類是在 FabricJS 1.4 版本中引入的,它擴充套件了 fabric.Text 並用於建立 IText 例項。IText 例項使我們可以自由地選擇、剪下、貼上或新增新文字,無需額外的配置。它還支援各種快捷鍵組合和滑鼠/觸控組合,使文字具有互動性,而這些功能在 Text 中是沒有的。
然而,基於 IText 的文字框允許我們調整文字矩形的大小並自動換行。這對於 IText 來說是不正確的,因為高度不會根據換行進行調整。我們可以使用各種屬性來操作 IText 物件。同樣,我們也可以使用 findWordBoundaryRight 方法找到單詞的右邊界。
語法
findWordBoundaryRight(startFrom: Number): Number
引數
startFrom − 此引數接受一個數字,表示當前的選擇索引,將返回右邊界值的新選擇索引。
示例 1
使用 findWordBoundaryRight 方法
讓我們來看一個程式碼示例,看看使用findWordBoundaryRight方法時記錄的輸出。這裡,我們傳入的值為 5,這意味著我們想要檢查第二個單詞的右邊界。因此,返回值將為 10。
<!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>Using the findWordBoundaryRight method</h2> <p>You can open console from dev tools and see that the right boundary value is being displayed in the console </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 an itext object var itext = new fabric.IText("Add sample text here.", { width: 300, left: 60, top: 70, fill: "red", }); // Add it to the canvas canvas.add(itext); // Using findWordBoundaryRight method console.log("The new selection index is: ", itext.findWordBoundaryRight(5)); </script> </body> </html>
示例 2
使用 findWordBoundaryRight 方法計算第一個單詞的單詞邊界
讓我們來看一個程式碼示例,看看我們如何使用findWordBoundaryRight方法找到第一個單詞的新選擇索引。在這種情況下,我們為 startFrom 引數傳遞了值 1,它將位於第一個單詞中。因此,返回的新選擇索引值將為 3,即右邊界。
<!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>Using the findWordBoundaryRight method to calculate the word boundary for the first word</h2> <p> You can open console from dev tools and see that the right boundary value is being displayed in the console </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 an itext object var itext = new fabric.IText("Add sample text here.", { width: 300, left: 60, top: 70, fill: "red", }); // Add it to the canvas canvas.add(itext); // Using findWordBoundaryRight method console.log("The new selection index is: ", itext.findWordBoundaryRight(1)); </script> </body> </html>
廣告
資料結構
網路
關係資料庫管理系統 (RDBMS)
作業系統
Java
iOS
HTML
CSS
Android
Python
C 語言程式設計
C++
C#
MongoDB
MySQL
Javascript
PHP