【问题标题】:How to use mouse click and drag to zoom in D3如何使用鼠标单击和拖动来放大 D3
【发布时间】:2012-07-02 23:56:25
【问题描述】:

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

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

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

【问题讨论】:

    标签: javascript d3.js


    【解决方案1】:

    您可能希望使用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 的当前范围重绘数据的函数。这样您就不需要尝试挂钩自己的处理程序,甚至根本不需要担心调整突出显示区域的大小。

    【讨论】:

      猜你喜欢
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 2017-05-03
      • 2015-07-18
      • 1970-01-01
      • 2019-12-10
      • 2011-08-27
      相关资源
      最近更新 更多