【 D3.js 進階系列 — 6.1 】 縮放的應用(Zoom)


縮放(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("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");

3. 結果

結果如下,在圓上滑動鼠標滾輪試試:

源代碼單擊以下鏈接后查看:

http://www.ourd3js.com/demo/J-6.1/zoom.html

謝謝閱讀。

文檔信息


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM