缩放(Zoom)是另一种重要的可视化操作,主要是使用鼠标的滚轮进行。
1. zoom 的定义
缩放是由 d3.behavior.zoom() 定义的。
var zoom = d3.behavior.zoom()
.scaleExtent([1, 10])
.on("zoom", zoomed);
function zoomed() {
circles_group.attr("transform",
"translate(" + d3.event.translate + ")scale(" + d3.event.scale + ")");
}
第 2 行:scaleExtent 用于设置最小和最大的缩放比例
第 3 行:当 zoom 事件发生时,调用 zoomed 函数
第 5 - 8 行:zoomed 函数,用于更改需要缩放的元素的属性,d3.event.translate 是平移的坐标值,d3.event.scale 是缩放的值。
2. 绘制圆
与【进阶 - 第 6.0 章】一样,绘制两个圆用于测试。只是将圆 circle 元素添加到一个组 g 里,g 元素调用 call(zoom),zoom 为刚才定义的缩放行为。
var circles_group = svg.append("g")
.call(zoom);
circles_group.selectAll("circle")
.data(circles)
.enter()
.append(

本文介绍了D3.js中缩放(Zoom)行为的使用,通过定义d3.behavior.zoom()并设置scaleExtent,配合zoom事件处理函数实现元素的缩放和平移。通过实例展示了如何在圆上应用缩放效果,鼓励读者尝试滚动鼠标滚轮体验交互。文章提供了完整的源代码链接供参考。
最低0.47元/天 解锁文章
575

被折叠的 条评论
为什么被折叠?



