如何使用鼠标单击并拖动以放大D3

时间:2012-07-02 23:56:26

标签: javascript d3.js

我是D3新手,想要实现类似于此处显示的点击 - 拖动缩放:http://www.highcharts.com/demo/line-time-series

我已经有一个我已经构建的折线图,但我对如何实现它感到困惑。

我想我需要一些JS事件处理程序来查找我的mousedown和mouseup发生的位置。但是,如何在用户拖动时创建图形上出现的阴影?

1 个答案:

答案 0 :(得分:4)

您可能希望使用brushd3.js中执行此操作。你可以看到我在http://bl.ocks.org/1962173放在一起做的类似的例子。

相关代码是:

var brush = d3.svg.brush()
    .x(x)
    .extent([d3.time.monday(now),d3.time.saturday.ceil(now)])
    .on("brush", display);

其中display是一个根据当前brush范围重绘数据的函数。这样您就不需要尝试挂钩自己的处理程序,甚至无需担心调整突出显示区域的大小。