树状图点击节点居中 d3.js@3.x

v4以上的api 没搞懂


 


var width = document.getElementById("tree").offsetWidth;
var height = document.getElementById("tree").offsetHeight;

var zoom = d3.behavior.zoom().center([width, height]).scaleExtent([0.1, 100]).on("zoom", zoomed);//添加放大缩小事件

function zoomed() {
	svg.attr("transform",
		"translate(" + d3.event.translate + ")" +
		"scale(" + d3.event.scale + ")"
	);
}
var svg = d3.select("body").select("#tree").append("svg")
		.call(zoom)//给svg绑定zoom事件、
		.append("g")
		// .attr("transform", "translate(150,0)")
		.attr("transform", "translate(" + width / 4 + ","+ 0 +")")

	// zoom.translate([150,0])
	zoom.translate([width / 4,0])

点击事件中执行下面操作 在vue中注意指向问题。


svg.attr('transform', 'translate(' + (width / 4 - d.y0) + ', ' + (height / 2 - d.x0) + ')')
zoom.translate([(width / 4 - d.y0), (height / 2 - d.x0)]).scale(1)

// 加了缩放以后但是他的距离又无法控制。
const a = zoom.scale()
svg.attr('transform', 'translate(' + (width / 4 - d.y0 * a) + ', ' + (height / 2 - d.x0 * a) + ') scale(' + a + ')')
zoom.translate([(width / 4 - d.y0 * a), (height / 2 - d.x0 * a)]).scale(a)

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值