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


d3.js zoom.translateExtent()用法及代碼示例


D3.js中的zoom.translateExtent()函數用於將轉換範圍設置為指定的點數組[[左上角,右下角]],並返回此縮放行為。

用法:

zoom.translateExtent([extent])

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

  • extent:此參數用於將車輪增量函數設置為指定函數。

返回值:此函數返回縮放行為。

以下示例程序旨在說明D3.js中的zoom.translateExtent()函數



範例1:

<!DOCTYPE html>  
<html>  
<head>  
    <meta charset="utf-8"> 
        
    <script src= 
            "https://d3js.org/d3.v4.min.js">  
    </script> 
       
    <script src= 
"https://cdnjs.cloudflare.com/ajax/libs/d3/5.7.0/d3.min.js"> 
    </script> 
</head>  
      
<body>  
    <center> 
        <h1 style="color:green;">  
            Geeksforgeeks  
        </h1>  
        
        <h3> 
  D3.js | zoom.translateExtent() Function 
      </h3> 
          
        <div id="GFG"></div> 
          
        <script> 
            var height = 300; 
            var width = 300; 
              
            var zoom = d3.zoom() 
               .translateExtent([[0, 0], [300, 300]]) 
                .on("zoom", zoomed); 
              
            var svg = d3.select("#GFG") 
                    .append("svg") 
                    .attr("width", height) 
                    .attr("height", width) 
                    .append("g") 
                      
            svg.append("rect") 
                    .attr("x", 0) 
                    .attr("y", 0) 
                    .attr("height", 200) 
                    .attr("width", 400) 
                    .style("fill", "green"); 
                         
                var circle = svg.append("circle") 
                    .attr("cx", 100) 
                    .attr("cy", 100) 
                    .attr("r", 20) 
                    .style("fill", "red") 
                      
                svg.call(zoom); 
                  
                function zoomed() { 
                  circle.attr( 
                    "transform", d3.event.transform); 
                } 
        </script>  
    </center> 
</body>  
    
</html>

輸出:

範例2:

<!DOCTYPE html> 
<html> 
    <head> 
        <meta charset="utf-8" /> 
  
        <script src= 
            "https://d3js.org/d3.v4.min.js"> 
      </script> 
  
        <script src= 
"https://cdnjs.cloudflare.com/ajax/libs/d3/5.7.0/d3.min.js"> 
      </script> 
  
        <style> 
            #svg { 
                background-color:rgb(149, 160, 230); 
            } 
            #shape { 
                fill:rgb(232, 7, 228); 
                stroke:white; 
                stroke-width:3px; 
            } 
            #shape:hover { 
                fill:rgb(13, 214, 30); 
            } 
        </style> 
    </head> 
  
    <body> 
        <center> 
            <h1 style="color:green;"> 
                Geeksforgeeks 
            </h1> 
  
            <h3>D3.js | zoom.translateExtent() Function</h3> 
  
            <div id="GFG"></div> 
  
            <script> 
                var width = 300, 
                    height = 200; 
  
                var container = 
                    d3.select("#GFG").append("div"); 
  
                var svg =  
                    container.append( 
                      "svg").attr( 
                      "id", "svg").attr( 
                      "width", width).attr( 
                      "height", height); 
  
                var group = svg.append("g"); 
  
                var shape = group.append( 
                  "rect").attr( 
                  "id", "shape").attr( 
                  "width", 150).attr( 
                  "height", 100).attr( 
                  "x", 75).attr("y", 50); 
  
                zoom = d3 
                    .zoom() 
                    .scaleExtent([1, 3]) 
                    .translateExtent([ 
                        [0, 0], 
                        [width, height], 
                    ]) 
                    .on("zoom", zoomed); 
  
                svg.call(zoom); 
  
                function zoomed() { 
                    change = d3.event.transform; 
                    console.log(change); 
                    group.attr("transform", "translate(" + 
                    [change.x, change.y] + ")scale(" +  
                    change.k + ")"); 
                    group.select("#shape").style( 
                        "stroke-width", 3 / change.k + "px"); 
                } 
            </script> 
        </center> 
    </body> 
</html>

輸出:




相關用法


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