The zoom.scaleBy() Function in D3.js is used to scale the current zoom transform of the selected elements by k. The reference point p does move.
Syntax:
zoom.scaleBy(selection, k[, p])
Parameters: This function accepts three parameters as mentioned above and described below:
- selection: This parameter can be selection or transition.
- k: This parameter is a scale factor, specified either as numbers or as functions
- p: The value of p is not specified, it defaults value is the center of the viewport extent.
Return Value: This function returns the zoom behavior.
Below programs illustrate the zoom.scaleBy() function in D3.js
Example 1:
HTML
| <!DOCTYPE html>  <html>   Â<head>      <metacharset="utf-8">      Â    <scriptsrc=     </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>         <h1style="color: green;">              Geeksforneveropen          </h1>       Â        <h3>             D3.js | zoom.scaleBy() Function         </h3>          Â        <svg>  Â            <gclass="zoom-controls"transform="translate(10, 10)">  Â                <gid="zoom-in"transform="translate(0, 0)">  Â                    <rectwidth="30"height="30"></rect>  Â                    <linex1="5"y1="15"x2="25"y2="15"></line>  Â                    <linex1="15"y1="5"x2="15"y2="25"></line>                 </g>  Â                <gid="zoom-out"transform="translate(30, 0)">  Â                    <rectwidth="30"height="30"></rect>  Â                    <linex1="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> | 
Output:
Example 2:
HTML
| <!DOCTYPE html>  <html>  <head>      <metacharset="utf-8">      Â    <scriptsrc=     </script>      Â</head>     Â<body>      <center>         <h1style="color: green;">              Geeksforneveropen          </h1>       Â        <h3>D3.js | zoom.scaleBy() Function</h3>          Â        <svgheight="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> | 
Output:


 
                                    








