javascript - d3.js:仅显示 xAxis 上的部分数据

标签 javascript d3.js

我正在使用具有缩放/平移功能的线性比例图表来显示大型数据集(500 多个点)。这是我用来构造 x 尺度的代码:

x = d3.scale.linear()
 .domain([0, data.length-1])
 .range([0, w]);

这样所有数据都被压缩到图表中,无法查看图像顶部的详细信息: example

我想显示类似于底部图表的数据(并让用户使用平移功能滚动查看更多数据)。

最佳答案

实现此目的的一种方法是操纵 X 尺度的域,使其将缩放边界映射为映射到范围的 0 宽度值的最小/最大域值。然后,您可以使用剪辑路径剪辑/隐藏绘制在 X 比例范围之外的绘图部分。

使用 jsFiddle 示例可能更有意义:http://jsfiddle.net/reblace/8TmM9/

在这个例子中,有 10 个正方形总是被绘制。您可以检查 dom 以了解我在说什么。但是,有一个剪辑路径的宽度只够您一次看到其中的 4 个。 X 尺度将 0-9 的输入值映射到输出坐标。范围设置为 0 到绘制所有 10 个正方形所需的宽度,域设置为 [0, 9]。

var xScale = d3.scale.linear()
    .domain(d3.extent(data))
    .range([0, width]);
...

var svg = d3.select('#chart').append('svg')
    .attr('width', clipWidth)
    .attr('height', clipHeight);

svg.append("defs").append("clipPath")
    .attr("id", "clip")
    .append("rect")
        .attr("width", clipWidth)
        .attr("height", clipHeight);

...

var g = svg.append("g");
g.selectAll("rect")
    .data(data).enter().append('rect')
        .attr("class", "area").attr("clip-path", "url(#clip)")
        .attr('x', xScale)
        .attr('width', rectWidth)
        .attr('height', rectHeight)
        .style('fill', d3.scale.category20());

最初,这将在可见 Pane 中绘制前四个矩形。通过操纵域使其变为 [1,10] 或 [2,11] 甚至 [-1, 8],我们可以有效地左右移动绘制的元素,以便绘制不同的绘图跨度可见区域。

// Pan Left
xScale.domain([xScale.domain()[0] - 1, xScale.domain()[1] - 1]);

// Pan Right
xScale.domain([xScale.domain()[0] + 1, xScale.domain()[1] + 1]);

无论您是使用正方形还是绘图,此技术都是相同的。

Mike Bostock 有一个示例,它也按照您在此处尝试的方式对绘图执行此操作:Focus+Context http://bl.ocks.org/mbostock/1667367

关于javascript - d3.js:仅显示 xAxis 上的部分数据,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/24490261/

相关文章:

javascript - 如何在 Javascript 中添加注册日期?

javascript - Javascript 对象文字表示法的意外行为

javascript - 将 Stringarray 交给 django 模板并在 d3 中使用它

D3.js v6.2 - 在监听器函数中获取数据索引 - selection.on ('click',监听器)

javascript - 使用 OpenLayers 和 GeoJSON 创建锥形线

javascript - 如何通过 url 重写在 Web 元素中正确缩小/合并 CSS/JS

javascript - 购物车输入未在 Stripe 表单中正确显示

javascript - D3.js:折线图中水平和垂直焦点线(十字线)的位置错误

javascript - d3.js 使用相同的选择选项控制两个图形

d3.js - 使用大型数据集和 d3.scale.linear() 时,使 dc.js 中的条宽和间隙保持一致