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


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


D3.js中的zoom.clickDistance()函數用於設置鼠標可以在mousedown和mouseup之間移動的最大距離,這將觸發隨後的單擊事件。

用法:

zoom.clickDistance([distance])

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

  • distance:此參數是最大距離。

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

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



範例1:

<!DOCTYPE html>  
<html>  
<head>  
    <meta charset="utf-8"> 
    <script src="https://d3js.org/d3.v4.min.js">  
    </script> 
      
    <style> 
        circle { 
          opacity:0.7; 
        } 
    </style> 
     
</head>  
    
<body>  
    <center> 
        <h1 style="color:green;">  
            Geeksforgeeks  
        </h1>  
      
        <h3>D3.js | zoom.clickDistance() Function</h3> 
          
        <svg></svg> 
          
        <script> 
            var radius = 15; 
            var svg = d3.select('svg');   
            var dimension = document.body 
                .getBoundingClientRect(); 
              
            var data = d3.range(0, 50).map(function () { 
                return { 
                x:getRandom(radius, 400 - radius), 
                y:getRandom(radius, 200 - radius) 
              } 
            }); 
              
            var zoom = d3.zoom() 
                .clickDistance(4) 
                .on('zoom', function() { 
                canvas.attr('transform', d3.event.transform); 
              }) 
              
            var canvas = svg.attr('width', 400) 
                .attr('height', 200) 
                .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)] 
                }); 
              
            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:

<!DOCTYPE html>  
<html>  
<head>  
    <meta charset="utf-8"> 
    <script src="https://d3js.org/d3.v4.min.js">  
    </script> 
      
    <style> 
        circle { 
          opacity:0.7; 
          fill:#e854c8; 
        } 
    </style> 
     
</head>  
    
<body>  
    <center> 
        <h1 style="color:green;">  
            Geeksforgeeks  
        </h1>  
      
        <h3> 
D3.js | zoom.clickDistance() Function 
        </h3> 
          
        <svg ></svg> 
          
        <script> 
            var transform =  
d3.zoomIdentity.translate(100, 0).scale(1); 
            var zoom = d3.zoom().on("zoom", handleZoom); 
                
            var svg = d3.select("svg") 
              .attr('width', 400) 
              .attr('height', 200) 
              .style("background", "#0ec924") 
              .call(zoom)                       
              .call(zoom.transform, transform); 
          
            var zoomable = svg 
              .append("g") 
              .attr("class", "zoomable") 
              .attr("transform", transform);    
                
            var circles = zoomable.append('circle') 
              .attr("id", "circles") 
              .attr("cx", 100) 
              .attr("cy", 100) 
              .attr('r', 30); 
          
            function handleZoom(){ 
              if (zoomable) { 
                zoomable.attr( 
            "transform", d3.event.transform); 
              } 
            }; 
  
        </script>  
    </center> 
</body>  
  
</html> 

輸出:




相關用法


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