在D3多线图上创建点

时间:2013-09-09 07:02:22

标签: d3.js

我正在尝试使用此示例中的d3向线图添加点: http://bl.ocks.org/mbostock/3884955

我也试图关注this post

如何从文档中获得这些图片的分数? http://github.com/mbostock/d3/wiki/line.png

圆的笔划应与线条颜色匹配。

var color = d3.scale.category10();


  d3.csv("data.csv", function(error, data) {
  color.domain(d3.keys(data[0]).filter(function(key) { return key !== "date"; }));

  data.forEach(function(d) {
    d.date = parseDate(d.date);
  });

  var ranks = color.domain().map(function(name) {
    return {
      name: name,
      values: data.map(function(d) {
        return {date: d.date, ranking: +d[name]};
      })
    };
  });



  var rank = svg.selectAll(".rank")
      .data(ranks)
    .enter().append("g")
      .attr("class", "rank");
    rank.append("path")
      .attr("class", "line")
      .attr("d", function(d) { return line(d.values); })
      .style("stroke", function(d) { return color(d.name); });



var point = rank.append("g")
.attr("class", "line-point");

point.selectAll('circle')
.data(function(d){ return d.values})
.enter().append('circle')
.attr("cx", function(d) { return x(d.date) })
.attr("cy", function(d) { return y(d.ranking) })
.attr("r", 3.5)
.style("fill", "white")
.style("stroke", function(d) { return color(d.name); });

1 个答案:

答案 0 :(得分:16)

.style("stroke", function(d) { return color(this.parentNode.__data__.name); })

See JSBin code
找到答案here