我正在用 d3 的可拖动 svg 的圆圈写一个图表。到目前为止,我有这样的事情:
var drag1 = d3.behavior.drag()
.origin(function() {
var t = d3.select(this);
return {x: t.attr("x") + d3.transform(t.attr("transform")).translate[0],
y: t.attr("y") + d3.transform(t.attr("transform")).translate[1]};
})
.on("drag", function(d,i) {
d3.select(this).attr("transform", function(d,i){
return "translate(" + [ 0,d3.event.y ] + ")"
})
});
d3.selectAll("circle").call(drag1);
我想存储oldY
和mousedown
分配newY
。mouseup
.on("mousedown", function(d){
var th = d3.select(this);
d.oldY = +th.attr("cy");
})
.on("mouseup", function(d){
var th = d3.select( this );
var coordinates = [0, 0];
coordinates = d3.mouse( this.parentNode );
console.log( "d3.mouse( this.parentNode )[1] " + d3.mouse( this.parentNode )[1] );
console.log("d3.event.pageY " + d3.event.pageY);
console.log("th.attr('cy') " + th.attr("cy"));
//??
th.attr("cy",d3.event.pageY );
d.newY = ?? what ??
console.log(d);
});
我需要oldY
并且newY
出于另一个功能的目的,我该如何在拖动或更新 cx 和 cy 后获取圆的坐标?