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


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


D3.js中的zoom.scaleBy()函數用於按k縮放所選元素的當前縮放變換。參考點p確實移動。

用法:

zoom.scaleBy(selection, k[, p])

參數:此函數接受上述和以下所述的三個參數:

  • selection:該參數可以是選擇或轉換。
  • k:此參數是比例因子,可以指定為數字或函數
  • p:p的值未指定,默認值為視口範圍的中心。

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

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



範例1:

HTML

<!DOCTYPE html>  
<html>  
  
<head>  
    <meta charset="utf-8"> 
      
    <script src= 
        "https://d3js.org/d3.v4.min.js">  
    </script> 
      
    <style> 
        circle { 
          opacity:0.7; 
        } 
        g.zoom-controls { 
            cursor:pointer; 
            pointer-events:all; 
        } 
        g.zoom-controls rect { 
            fill:white; 
            stroke:#596877; 
            stroke-width:1; 
        } 
        g.zoom-controls line { 
            stroke:#596877; 
            stroke-width:2; 
        } 
    </style> 
</head>  
    
<body>  
    <center> 
        <h1 style="color:green;">  
            Geeksforgeeks  
        </h1>  
      
        <h3> 
            D3.js | zoom.scaleBy() Function 
        </h3> 
          
        <svg> 
  
            <g class="zoom-controls" transform="translate(10, 10)"> 
  
                <g id="zoom-in" transform="translate(0, 0)"> 
  
                    <rect width="30" height="30"></rect> 
  
                    <line x1="5" y1="15" x2="25" y2="15"></line> 
  
                    <line x1="15" y1="5" x2="15" y2="25"></line> 
                </g> 
  
                <g id="zoom-out" transform="translate(30, 0)"> 
  
                    <rect width="30" height="30"></rect> 
  
                    <line x1="5" y1="15" x2="25" y2="15"></line> 
  
                </g> 
  
            </g> 
  
        </svg> 
          
        <script> 
            var radius = 10; 
            var svg = d3.select('svg');   
            var dimension = document.body.getBoundingClientRect(); 
              
            var data = d3.range(0, 25).map(function() { 
                return { 
                x:getRandom(radius, dimension.width - radius), 
                y:getRandom(radius, dimension.height - radius) 
              } 
            }); 
              
            var zoom = d3.zoom() 
                .on('zoom', function() { 
                canvas.attr('transform', d3.event.transform); 
            }); 
              
            var canvas = svg 
                .attr('width', dimension.width) 
                .attr('height', dimension.height) 
                .call(zoom) 
                .insert('g', ':first-child'); 
  
            canvas.selectAll('circle') 
                .data(data) 
                .enter() 
                .append('circle') 
                .attr('r', radius) 
                .attr('cx', function(d) { 
                return d.x; 
                }).attr('cy', function(d) { 
                return d.y; 
                }).style('fill', function() { 
                return d3.schemeCategory10[getRandom(0, 9)] 
                }); 
              
            d3.select('#zoom-in').on('click', function() { 
                // Smooth zooming 
                zoom.scaleBy(svg.transition().duration(750), 1.3); 
            }); 
              
            d3.select('#zoom-out').on('click', function() { 
                // Ordinal zooming 
                zoom.scaleBy(svg, 1 / 1.3); 
            }); 
              
            function getRandom(min, max) { 
                min = Math.ceil(min); 
                max = Math.floor(max); 
                return Math.floor(Math.random() * (max - min + 1)) + min; 
            } 
        </script>  
    </center> 
</body>  
  
</html>

輸出:

範例2:

HTML

<!DOCTYPE html>  
<html>  
<head>  
    <meta charset="utf-8"> 
      
    <script src= 
        "https://d3js.org/d3.v5.js"> 
    </script> 
      
</head>  
    
<body>  
    <center> 
        <h1 style="color:green;">  
            Geeksforgeeks  
        </h1>  
      
        <h3>D3.js | zoom.scaleBy() Function</h3> 
          
        <svg height="100px" width="100px"></svg> 
          
        <script> 
            const zoom_action = () => g.attr("transform", d3.event.transform); 
  
            // Create the zoom handler 
            const zoom = d3.zoom() 
                    .on("zoom", zoom_action); 
              
            // Get SVG element and apply zoom behaviour 
            var svg = d3 
              .select("svg") 
              .call(zoom); 
              
            // Create Group that will be zoomed 
            var g = svg.append("g"); 
              
            // Create circle 
            g.append("circle") 
              .attr("cx",0) 
              .attr("cy",0) 
              .attr("r", 5) 
              .style("fill","green"); 
              
            // Use of zoom.scaleBy Function 
            zoom.scaleBy(svg, 5); 
            zoom.translateBy(svg, 50, 50); 
  
        </script>  
    </center> 
</body>  
  
</html>

輸出:




相關用法


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