D3:向多线图添加数据值标签

Fre*_*ier 2 javascript d3.js

我正在使用这个多线图,但到目前为止未能在每个刻度(每天)上生成数据值标签。

<script>

var margin = {top: 30, right: 40, bottom: 30, left: 50},
    width = 600 - margin.left - margin.right,
    height = 270 - margin.top - margin.bottom;

var parseDate = d3.time.format("%d-%m-%y").parse;

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

var xAxis = d3.svg.axis().scale(x)
    .orient("bottom").ticks(7);

var yAxis = d3.svg.axis().scale(y)
    .orient("left").ticks(7);

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

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

var svg = d3.select("body")
    .append("svg")
        .attr("width", width + margin.left + margin.right)
        .attr("height", height + margin.top + margin.bottom)
    .append("g")
        .attr("transform", "translate(" + margin.left + "," + margin.top + ")");

// Get the data
d3.csv("data.tsv", function(error, data) {
    data.forEach(function(d) {
        d.date = parseDate(d.date);
        d.sev3 = +d.sev3;
        d.sev4 = +d.sev4;
    });

    // Scale the range of the data
    x.domain(d3.extent(data, function(d) { return d.date; }));
    y.domain([0, d3.max(data, function(d) { return Math.max(d.sev3, d.sev4); })]);

    svg.append("path")      // Add the valueline path.
        .attr("class", "line")
        .attr("d", valueline(data));

    svg.append("path")      // Add the valueline2 path.
        .attr("class", "line")
        .style("stroke", "red")
        .attr("d", valueline2(data));



    svg.append("g")         // Add the X Axis
        .attr("class", "x axis")
        .attr("transform", "translate(0," + height + ")")
        .call(xAxis);

    svg.append("g")         // Add the Y Axis
        .attr("class", "y axis")
        .call(yAxis);

    svg.append("text")
        .attr("transform", "translate(" + (width+3) + "," + y(data[0].sev4) + ")")
        .attr("dy", ".35em")
        .attr("text-anchor", "start")
        .style("fill", "red")
        .text("Sev4");

    svg.append("text")
        .attr("transform", "translate(" + (width+3) + "," + y(data[0].sev3) + ")")
        .attr("dy", ".35em")
        .attr("text-anchor", "start")
        .style("fill", "steelblue")
        .text("Sev3");



});

</script>
Run Code Online (Sandbox Code Playgroud)

数据.tsv

date,sev3,sev4
20-02-15,0,0
19-02-15,0,0
18-02-15,0,0
17-02-15,481,200
16-02-15,691,200
15-02-15,296,200
14-02-15,307,200
Run Code Online (Sandbox Code Playgroud)

上面的代码给出了这个: 使用当前代码

这就是我想要完成的我想要的是

我知道我必须使用 .append("text") 并将文本定位在与数据点大致相同的 x,y 坐标处,并从数据中提取值以输入“文本”,但我在整合方面遇到困难那个概念。

我怀疑选择会发生在 valueline.append 吗?我查看了一堆示例,我不认为存在带有数据值标签的折线图,如果确实存在,请指点我:)

有什么想法吗 ?

Hug*_*ski 5

您的文本将不可见,因为它位于 svg 的边界之外:您添加了一个由 margin.left 翻译的组,并将您的 x 放在宽度 + 3 处,这意味着位于宽度 + 3 + 边距处。 svg 左边框的左侧。

尝试用以下内容替换您的附加文本:

svg.append("text")
    .attr("transform", "translate(" + (width/2) + "," + y(data[0].sev4) + ")")
    .attr("dy", ".35em")
    .attr("text-anchor", "start")
    .style("fill", "red")
    .text("Sev4");

svg.append("text")
    .attr("transform", "translate(" + (width/2) + "," + y(data[0].sev3) + ")")
    .attr("dy", ".35em")
    .attr("text-anchor", "start")
    .style("fill", "steelblue")
    .text("Sev3");
Run Code Online (Sandbox Code Playgroud)

我没有测试它,所以我不能保证,但你的代码看起来很好,这是我唯一看到的。

添加的结果: 您的建议仅将线标签移动到中心,但不会向数据点添加值标签

编辑

在您澄清之后,这里有一个 plunk:http ://plnkr.co/edit/lDlseqUQQXgoFwTK5Aop? p= preview

你会感兴趣的部分是:

svg.append('g')
.classed('labels-group', true)
.selectAll('text')
.data(data)
.enter()
.append('text')
.classed('label', true)
.attr({
  'x': function(d, i) {
    return x(d.date);
  },
  'y': function(d, i) {
    return y(d.sev3);
  }
})
.text(function(d, i) {
  return d.sev3;
});
Run Code Online (Sandbox Code Playgroud)

这将绘制您的标签。这是你试图达到的结果吗?