當前位置: 首頁>>代碼示例 >>用法及示例精選 >>正文


Fabric.js Polygon centeredScaling屬性用法及代碼示例


在本文中,我們將看到如何使用FabricJS啟用畫布多邊形的居中縮放。畫布“多邊形”表示多邊形是可移動的,可以根據需要進行拉伸。此外,當涉及初始筆觸顏色,高度,寬度,填充顏色或筆劃寬度時,可以自定義多邊形。

為了使之成為可能,我們將使用一個名為FabricJS的JavaScript庫。導入庫後,我們將在body標簽中創建一個canvas塊,其中將包含Polygon。此後,我們將初始化FabricJS提供的Canvas和Polygon實例,並使用centeredScaling屬性啟用畫布Polygon的居中縮放,並在Canvas上渲染Polygon,如下所示。

用法:

fabric.Polygon([ 
        { x:pixel, y:pixel }, 
        { x:pixel, y:pixel }, 
        { x:pixel, y:pixel }, 
        { x:pixel, y:pixel }, 
        { x:pixel, y:pixel }],
        {
                centeredScaling:boolean
        });

參數:該參數接受上述和以下描述的單個參數:

  • centeredScaling:它指定是啟用還是禁用居中縮放。

例:本示例使用FabricJS啟用下麵給出的canvas-like多邊形的居中縮放。啟用居中縮放後,嘗試縮放對象,縮放對象後,它將從各個方向縮放。



HTML

<!DOCTYPE html>  
<html>  
  
<head>  
    <!-- Loading the FabricJS library -->
    <script src=  
"https://cdnjs.cloudflare.com/ajax/libs/fabric.js/3.6.2/fabric.min.js">  
    </script>  
</head>  
  
<body>  
    <div style="text-align:center;width:600px;">  
        <h1 style="color:green;">  
            GeeksforGeeks  
        </h1>  
        <b>  
            Fabric.js | Polygon centeredScaling Property  
        </b>  
    </div>  
  
    <canvas id="canvas"
            width="600"
            height="200"
            style="border:1px solid #000000;">  
    </canvas>  
  
    <script>  
        // Initiate a Canvas instance  
        var canvas = new fabric.Canvas("canvas");  
  
        // Initiate a polygon instance  
        var polygon = new fabric.Polygon([  
            { x:295, y:10 },  
            { x:235, y:198 },  
            { x:385, y:78},  
            { x:205, y:78},  
            { x:355, y:198 }], {  
                stroke:'green',  
                strokeWidth:3,  
                centeredScaling:true  
            });  
  
        // Render the polygon in canvas  
        canvas.add(polygon);  
    </script>  
</body>  
  
</html>

輸出:




相關用法


注:本文由純淨天空篩選整理自skyridetim大神的英文原創作品 Fabric.js Polygon centeredScaling Property。非經特殊聲明,原始代碼版權歸原作者所有,本譯文未經允許或授權,請勿轉載或複製。