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>
輸出:
相關用法
- d3.js now()用法及代碼示例
- p5.js mag()用法及代碼示例
- PHP next()用法及代碼示例
- d3.js zip()用法及代碼示例
- d3.js lch()用法及代碼示例
- d3.js tsv()用法及代碼示例
- p5.js pan()用法及代碼示例
- CSS var()用法及代碼示例
- PHP Ds\Map get()用法及代碼示例
- PHP chr()用法及代碼示例
- PHP ord()用法及代碼示例
- CSS hsl()用法及代碼示例
- p5.js min()用法及代碼示例
注:本文由純淨天空篩選整理自SHUBHAMSINGH10大神的英文原創作品 D3.js zoom.scaleBy() Function。非經特殊聲明,原始代碼版權歸原作者所有,本譯文未經允許或授權,請勿轉載或複製。