8

我试图在 D3 中绘制一个简单的折线图,但有一些问题。

我希望图表是动态的 - 所以当数据更新时,我希望图表转换为新值。所以我需要在我的代码中的某个地方使用 D3 转换,我找不到一个用折线图来做这件事的好例子。

这是我的代码的相关部分。目前,这根本没有绘制任何东西。

var data = [
 {
  "air_produced": 0.660985, 
  "air_used": 0.342706, 
  "datestr": "2012-12-01 00:00:00", 
  "energy_used": 0.106402
 } ... ];
var parseDate = d3.time.format("%Y-%m-%d %H:%M:%S");
data.forEach(function(d) {
  d.date = parseDate.parse(d.datestr);
});

var x = d3.time.scale().range([0, width]);
var y = d3.scale.linear().range([height, 0]);

var line = d3.svg.line()
  .x(function(d) { return x(d.date); })
  .y(function(d) { return y(d.energy_used); });

// How to draw the line?
var linegraph = d3.select("path.line").datum(data);
line.transition().duration(1000).attr("d", line);
linegraph.enter().append("path")
    .attr("class", "line")
    .attr("d", line);

JSFiddle 这里有完整的图表:http: //jsfiddle.net/zNX8p/

4

2 回答 2

2

明白了(我认为):

var linegraph = svg.selectAll("path.line").data([data], function(d) { return d.date; });

linegraph.transition().duration(1000).attr('d', line);

linegraph.enter().append("path")
    .attr("class", "line")
    .attr("d", line);

datum不返回enter选择,因此您需要通过传递数据data

于 2013-09-17T12:17:11.507 回答
1

d3 有一个通用的更新模式,你应该在这种情况下使用它。

约定是有两个功能,一个是设置可视化,另一个是获取数据和更新可视化。

更新函数接收新数据,绑定它,更新图形,然后根据需要添加或删除对象。

Mike Bostock 有一个很棒的 3 部分系列解释这一点,你可以在这里找到:https ://twitter.com/mbostock/status/252496768267333632

于 2013-09-17T16:22:02.560 回答