我正在使用 d3 构建散点图,并且 x 和 y 轴的值集都有正值和负值。这是我第一次尝试使用 d3,我从介绍性教程中收集到,例如在圣诞节的第十天,使用 d3.js 弄脏数据,关键是正确设置 x 和 y 比例。
接下来,我找到了这个教程:带负值的条形图,它几乎帮助我做对了(我认为)。我的数据集太大,无法放在这里,但这里是我的数据示例代码:
<div id="compareAll"></div>
<script>
window.onload = function() {
var dataSet = [ [4,4], [-4,4], [-4,-4], [4,-4], ];
var x0 = Math.max(-d3.min(dataSet[0]), d3.max(dataSet[0]));
var xScale = d3.scale.ordinal()
.domain([-x0,x0])
.range([0,10]);
var yScale = d3.scale.ordinal()
.domain(d3.range(dataSet[1])
.rangeRoundBands([0,10]);
var svg = d3.select("#compareAll")
.append("svg")
.attr("width", 10)
.attr("height",10)
svg.selectAll("circle")
.data(dataSet)
.enter()
.append("circle")
.attr("cx", function(d) {
return xScale(d[0]);
})
.attr("cy", function(d) {
return yScale(d[1]);
})
.attr("r",4);
var xAxis = d3.svg.axis()
.scale(xScale)
.tickSize(1);
var yAxis = d3.svg.axis()
.scale(yScale)
.tickSize(1);
svg.append("svg:g")
.attr("class", "x axis")
.attr("transform", "translate(0,10)")
.call(xAxis);
svg.append("svg:g")
.attr("class", "y axis")
.attr("transform", "translate(10,0)")
.call(yAxis);
}
</script>
坦率地说,我不了解条形图示例中序数刻度的使用,但是当我将其取出并使用与 xScale 相同的语法制作 yScale 时,我得到的结果似乎更糟。
任何关于处理两个轴的正值和负值的最佳方法的解释都将不胜感激。让我知道我是否遗漏了一些明显的东西。我将这个来自一个更大项目的示例一起完成,以使其尽可能具体且易于阅读。
谢谢!