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>
輸出:
相關用法
- PHP imagecreatetruecolor()用法及代碼示例
- p5.js year()用法及代碼示例
- d3.js d3.utcTuesdays()用法及代碼示例
- PHP ImagickDraw getTextAlignment()用法及代碼示例
- PHP Ds\Sequence last()用法及代碼示例
- PHP array_udiff_uassoc()用法及代碼示例
- PHP geoip_continent_code_by_name()用法及代碼示例
- d3.js d3.map.set()用法及代碼示例
- PHP GmagickPixel setcolor()用法及代碼示例
- PHP opendir()用法及代碼示例
- PHP cal_to_jd()用法及代碼示例
- d3.js d3.bisectLeft()用法及代碼示例
- PHP stream_get_transports()用法及代碼示例
- PHP Ds\Deque pop()用法及代碼示例
注:本文由純淨天空篩選整理自SHUBHAMSINGH10大神的英文原創作品 D3.js zoom.translateExtent() Function。非經特殊聲明,原始代碼版權歸原作者所有,本譯文未經允許或授權,請勿轉載或複製。