我正在尝试实现与此类似的图表-
https://bl.ocks.org/syntagmatic/05a5b0897a48890133beb59c815bd953
在 d3 v4 中。所以我在这里找到了这个库 -
https://github.com/syntagmatic/parallel-coordinates
最初是用 d3 v4 编写的,所以我找到了一个部分移植的 d3 v4 版本——
https://github.com/mlarosa2/parcoords
为此,在将这个库与我的一些自定义项一起使用后,我在这里达到了这一点 -
http://blockbuilder.org/iamdeadman/9e7c89d21c7dc1ce1b13b1ceb931c9eb
因此,如果您打开该块,您会看到我无法再在 y 轴上绘制画笔。我相信这是因为这个库中的一些 d3.dispatch 事件问题。
这些是我必须做出的改变mlarosa2/parcoords
才能产生至少一个正在运行的演示 -
d3.svg.brush()
----到---> d3.brush()
;
brush.y(__.dimensions[axis].yscale)
.on("brushstart", function() {
if(d3.event.sourceEvent !== null) {
events.brushstart.call(pc, __.brushed);
d3.event.sourceEvent.stopPropagation();
}}).on("brush", function() {
brushUpdated(selected());}).on("brushend", function() {
events.brushend.call(pc, __.brushed);});
----to--->
brush.extent(__.dimensions[axis].yscale)
.on("start", function() {if(d3.event.sourceEvent !== null) {
// events.call('brushstart', pc, __.brushed);
events.brushstart.call(pc, __.brushed);
d3.event.sourceEvent.stopPropagation();
}})
.on("brush", function() {
brushUpdated(selected());
})
.on("end", function() {
// events.call('brushend', pc,__.brushed);
events.brushend.call(pc, __.brushed);
});
变了——
var brush = g.append("svg:g")
.attr("class", "brush")
.each(function(d) {
d3.select(this).call(brushFor(d));
});
----to--->
var brush = g.append("svg:g")
.attr("class", "brush")
.each(function(d) {
try {d3.select(this).call(brushFor(d));} catch(e){}
});
改为d3.svg.arc()
_d3.arc()
终于变了——
d3.selectAll([canvas.foreground, canvas.brushed]).classed("faded", true);
data.forEach(path_highlight);
events.highlight.call(this, data);
----to--->
d3.selectAll([canvas.foreground.clientWidth, canvas.brushed.clientWidth]).classed("faded", true);
data.forEach(path_highlight);
events.call('highlight', this, data);
任何人都可以提出任何更改/有用的提示来查找/调试以下块中的问题,以便我们可以像在https://bl.ocks.org/syntagmatic/05a5b0897a48890133beb59c815bd953中使用 d3 v4 一样创建和应用选择到 y 轴。
- 更新 -
因此,在 paracoords.js 中尝试了更多更改后,我们能够创建画笔句柄,但是在移动时画笔会刷新所有数据,而不仅仅是从画笔中选择点。我相信刷子设置存在一些错误,这就是为什么在刷子事件调用中无法访问所选点的原因。
任何人都可以看看这个问题并帮助看看这是否可以解决。