縮放(Zoom)是另外一種重要的可視化操做,主要是使用鼠標的滾輪進行。javascript
縮放是由 d3.behavior.zoom() 定義的。html
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 用於設置最小和最大的縮放比例java
第 3 行:當 zoom 事件發生時,調用 zoomed 函數app
第 5 - 8 行:zoomed 函數,用於更改須要縮放的元素的屬性,d3.event.translate 是平移的座標值,d3.event.scale 是縮放的值。svg
與【進階 - 第 6.0 章】同樣,繪製兩個圓用於測試。只是將圓 circle 元素添加到一個組 g 裏,g 元素調用 call(zoom),zoom 爲剛纔定義的縮放行爲。wordpress
var circles_group = svg.append("g") .call(zoom); circles_group.selectAll("circle") .data(circles) .enter() .append("circle") .attr("cx",function(d){ return d.cx; }) .attr("cy",function(d){ return d.cy; }) .attr("r",function(d){ return d.r; }) .attr("fill","black");
結果以下,在圓上滑動鼠標滾輪試試:函數
源代碼單擊如下連接後查看:測試
http://www.ourd3js.com/demo/J-6.1/zoom.html.net
謝謝閱讀。code